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Foreword 



rd , 



This Technical Specification has been produced by the 3 Generation Partnership Project (3 GPP). This document 
describes the Extended Adaptive Multi-Rate Wideband (AMR-WB+) coder within the 3 GPP system. 

The contents of the present document are subject to continuing work within the TSG and may change following formal 
TSG approval. Should the TSG modify the contents of the present document, it will be re-released by the TSG with an 
identifying change of release date and an increase in version number as follows: 

Version x.y.z 

where: 

X the first digit: 

1 presented to TSG for information; 

2 presented to TSG for approval; 

3 or greater indicates TSG approved document under change control. 

y the second digit is incremented for all changes of substance, i.e. technical enhancements, corrections, 
updates, etc. 

z the third digit is incremented when editorial only changes have been incorporated in the document. 
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Scope 



This Telecommunication Standard (TS) describes the detailed mapping from input blocks of monophonic or 
stereophonic audio samples in 16 bit uniform PCM format to encoded blocks and from encoded blocks to output blocks 
of reconstructed monophonic or stereophonic audio samples. The coding scheme is an extension of the AMR-WB 
coding scheme [3] and is referred to as extended AMR-WB or AMR-WB + codec. It comprises all AMR-WB speech 
codec modes including VAD/DTX/CNG [2] [8] [10] as well as extended functionality for encoding general audio signals 
such as music, speech, mixed, and other signals. 

In the case of discrepancy between the requirements described in the present document and the ANSI-C code 
computational description of these requirements contained in [4], [5], the description in [4], [5], respectively, will 
prevail. The ANSI-C code is not described in the present document, see [4], [5] for a description of the floating-point 
or, respectively, fixed-point ANSI-C code. 
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3 Definitions and abbreviations 

3.1 Definitions 

For the purposes of the present document, the following terms and apply. 

adaptive codebook: The adaptive codebook contains excitation vectors that are adapted for every subframe. The 
adaptive codebook is derived from the long-term filter state. The lag value can be viewed as an index into the adaptive 
codebook. 

algebraic codebook: A fixed codebook where algebraic code is used to populate the excitation vectors (innovation 
vectors). The excitation contains a small number of nonzero pulses with predefined interlaced sets of potential 
positions. The amplitudes and positions of the pulses of the k^^ excitation codevector can be derived from its index k 
through a rule requiring no or minimal physical storage, in contrast with stochastic codebooks whereby the path from 
the index to the associated codevector involves look-up tables. 

anti-sparseness processing: An adaptive post-processing procedure applied to the fixed codebook vector in order to 
reduce perceptual artifacts from a sparse fixed codebook vector. 

closed-loop pitch analysis: This is the adaptive codebook search, i.e., a process of estimating the pitch (lag) value from 
the weighted input speech and the long term filter state. In the closed-loop search, the lag is searched using error 
minimization loop (analysis-by-synthesis). In the adaptive multi-rate wideband codec, closed-loop pitch search is 
performed for every subframe. 

direct form coefficients: One of the formats for storing the short term filter parameters. In the adaptive multi-rate 
wideband codec, all filters which are used to modify speech samples use direct form coefficients. 

fixed codebook: The fixed codebook contains excitation vectors for speech synthesis filters. The contents of the 
codebook are non-adaptive (i.e., fixed). In the adaptive multi-rate wideband codec, the fixed codebook is implemented 
using an algebraic codebook. 

fractional lags: A set of lag values having sub-sample resolution. In the adaptive multi-rate wideband codec a 
sub-sample resolution of V4* or Vi^ of a sample is used. 

super frame: A time interval equal to 1024 samples (80ms at a 12.8 kHz sampling rate). 

frame: A time interval equal to 256 samples (20ms at a 12.8 kHz sampling rate). 

Immittance Spectral Frequencies: (see Immittance Spectral Pair) 

Immittance Spectral Pair: Transformation of LPC parameters. Immittance Spectral Pairs are obtained by 
decomposing the inverse filter transfer function A(z) to a set of two transfer functions, one having even symmetry and 
the other having odd symmetry. The Immittance Spectral Pairs (also called as Immittance Spectral Frequencies) are the 
roots of these polynomials on the z-unit circle. 

integer lags: A set of lag values having whole sample resolution. 

interpolating filter: An FIR filter used to produce an estimate of sub-sample resolution samples, given an input 
sampled with integer sample resolution. In this implementation, the interpolating filter has low pass filter 
characteristics. Thus the adaptive codebook consists of the low-pass filtered interpolated past excitation. 

inverse filter: This filter removes the short term correlation from the speech signal. The filter models an inverse 
frequency response of the vocal tract. 

lag: The long term filter delay. This is typically the true pitch period, or its multiple or sub-multiple. 

LP analysis window: For each frame, the short term filter coefficients are computed using the high pass filtered speech 
samples within the analysis window. In the adaptive multi-rate wideband codec, the length of the analysis window is 
always 384 samples. For all the modes, a single asymmetric window is used to generate a single set of LP coefficients. 
The 5 ms look-ahead is used in the analysis. 

LP coefficients: Linear Prediction (LP) coefficients (also referred as Linear Predictive Coding (LPC) coefficients) is a 
generic descriptive term for the short term filter coefficients. 
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open-loop pitch search: A process of estimating the near optimal lag directly from the weighted speech input. This is 
done to simplify the pitch analysis and confine the closed-loop pitch search to a small number of lags around the 
open-loop estimated lags. In the adaptive multi-rate wideband codec, an open-loop pitch search is performed in every 
other subframe. 

residual: The output signal resulting from an inverse filtering operation. 

short term synthesis filter: This filter introduces, into the excitation signal, short term correlation which models the 
impulse response of the vocal tract. 

perceptual weighting filter: This filter is employed in the analysis-by-synthesis search of the codebooks. The filter 
exploits the noise masking properties of the formants (vocal tract resonances) by weighting the error less in regions near 
the formant frequencies and more in regions away from them. 

subframe: A time interval equal to 64 samples (5ms at 12.8 kHz sampling rate). 

vector quantization: A method of grouping several parameters into a vector and quantizing them simultaneously. 

zero input response: The output of a filter due to past inputs, i.e. due to the present state of the filter, given that an 
input of zeros is applied. 

zero state response: The output of a filter due to the present input, given that no past inputs have been applied, i.e., 
given that the state information in the filter is all zeroes. 

3.2 Abbreviations 

For the purposes of the present document, the following abbreviations apply: 

TCX Transform coded excitation 

ACELP Algebraic Code Excited Linear Prediction 

AGC Adaptive Gain Control 

AMR Adaptive Multi-Rate 

AMR-WB Adaptive Multi-Rate Wideband 

AMR-WB+ Extended Adaptive Multi-Rate Wideband 

CELP Code Excited Linear Prediction 

FIR Finite Impulse Response 

ISF Immittance Spectral Frequency 

ISP Immittance Spectral Pair 

ISPP Interleaved Single-Pulse Permutation 

LP Linear Prediction 

LPC Linear Predictive Coding 

LTP Long Term Predictor (or Long Term Prediction) 

MA Moving Average 

MRWB-ACELP Wideband Multi-Rate ACELP 

S-MSVQ Split-MultiStage Vector Quantization 

WB Wideband 



4 Outline description 

This TS is structured as follows: 

Section 4.1 contains a functional description of the audio parts including the A/D and D/A functions. Section 4.2 
describes input format for the AMR-WB+ encoder and the output format for the AMR-WB+ decoder. Section 4.3 
presents a simplified description of the principles of the AMR-WB codec. In subclause 4.4, the sequence and subjective 
importance of encoded parameters are given. 

Section 5 presents the functional description of the encoding functions of the AMR-WB+ extension modes, whereas 
clause 6 describes the decoding procedures for the extension modes. In section 7, the detailed bit allocation of the 
AMR-WB + codec extension modes is tabulated. The AMR-WB speech modes are functionally unchanged as well as 
their bit allocation. Detailed information on them is found in [1]. 
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4.1 Functional description of audio parts 

The analogue-to-digital and digital-to-analogue conversion will in principle comprise the elements given below. In case 
of stereo codec operation, the given principles will be applied to the 2 available audio channels. 

1) Analogue to uniform digital PCM 

- microphone; 

- input level adjustment device; 

- input anti-aliasing filter; 

- sample-hold device sampling at 16/24/32/48 kHz; 

- analogue-to-uniform digital conversion to 16-bit representation. 
The uniform format shall be represented in two's complement. 

2) Uniform digital PCM to analogue 

- conversion from 16-bit uniform PCM sampled at 16/24/32/48 kHz to analogue; 

- a hold device; 

- reconstruction filter including x/sin( x ) correction; 

- output level adjustment device; 

- earphone or loudspeaker. 

In the terminal equipment, the A/D function may be achieved 

- by direct conversion to 14-bit uniform PCM format; 
For the D/A operation, the inverse operations take place. 



4.2 Preparation of input samples 



The encoder is fed with data from one/two input channels comprising of samples with a resolution of 16 bits in a 16-bit 
word. The decoder outputs data in the same format and number of output channels. Though, mono output of decoded 
stereo signals is supported. 

4.3 Principles of the extended adaptive multi-rate wideband 
codec 

The AMR-WB+ audio codec contains all the AMR-WB speech codec modes 1-9 and AMR-WB VAD and DTX. AMR- 
WB+ extends the AMR-WB codec by adding TCX, bandwidth extension, and stereo. 

The AMR-WB+ audio codec processes input frames equal to 2048 samples at an internal sampling frequency F^ . The 
internal sampling frequency is limited to the range 12800-38400 Hz, see section 8 for more details. The 2048-sample 
frames are split into two critically sampled equal frequency bands. This results in two superframes of a 1024 samples 
corresponding to the low frequency (LF) and high frequency (HF) band. Each superframe is divided into four 256- 
samples frames. 

Sampling at the internal sampling rate is obtained by using a variable sampling conversion scheme, which re-samples 
the input signal. 

The LF and HF signals are then encoded using two different approaches: the LF is encoded and decoded using the 
"core" encoder/decoder, based on switched ACELP and transform coded excitation (TCX). In ACELP mode, the 
standard AMR-WB codec is used. The HF signal is encoded with relatively few bits (16 bits/frame) using a bandwidth 
extension (BWE) method. 
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The basic set of rates are built based on AMR-WB rates in addition to bandwidth extension. The basic set of mono rates 
are shown in Table 1 . 

Table 1 : Basic set of mono rates 



Mono rate(incl. BWE) 
(bits/frame) 


Corresponding AMR-WB mode 


208 


NA 


240 


NA 


272 


12.65 


304 


14.25 


336 


15.85 


384 


18.25 


416 


19.85 


480 


23.05 



Note that in ACELP mode of operation, compared to AMR-WB, the VAD bit is removed, two bits per frame are added 
for gain prediction, and 2 bits are added for signaling frame encoding type. This adds 3 bits per frame. Note also that 16 
bits/frame is always used for bandwidth extension (to encode the HF band). The first two basic mono rates are similar to 
other rates except that they use a fixed codebook with 20 bits or 28 bits, respectively. 

For stereo coding, the set of stereo extension rates given in Table 2 are used. 

Table 2: Basic set of stereo rates 



Stereo extension rates (incl. BWE) 
(Bits/frame) 


40 


104 


48 


112 


56 


120 


64 


128 


72 


136 


80 


144 


88 


152 


96 


160 



Note that the bandwidth extension is applied to both channels which requires additional 16 bits/frame for the stereo 
extension. 

A certain mode of operation is obtained by choosing a rate from Table 1 , in case of mono operation, or by combining a 
rate from Table 1 with a stereo extension rate from Table 2, in case of stereo operation. The resulting coding bitrate is 
(mono rate + stereo rate) Fs / 512. 

Examples: 

• For an internal sampling frequency of 32 kHz by choosing mono rate equal to 384 bits/frame and without 
stereo, we can obtain a bit-rate equal to 24 kbps and the frame length would be of a 16 ms duration. 

• For an internal sampling frequency of 25.6 kHz by choosing mono rate equal to 272 bits/frame and stereo rate 
equal to 88 bits/frame, we can obtain a bit-rate equal to 18 kbps and the frame length would be of a 20 ms 
duration. 

Note. The documentation of the AMR-WB + floating-point C-code in [4] contains further information on how to use 
the executables compiled from this source code to exercise the various possible uses, in the codec, of 
mono bit rate, stereo bit rate and internal sampling frequency, and the resulting total bit rates. 



4.3.1 Encoding and decoding structure 

Figure 1 presents the AMR-WB+ encoder structure. The input signal is separated in two bands. The first band is the 
low-frequency (LF) signal, which is critically sampled at Fs/2 . The second band is the high-frequency (HF) signal, 
which is also downsampled to obtain a critically sampled signal. The LF and HF signals are then encoded using two 
different approaches: the LF signal is encoded and decoded using the "core" encoder/decoder, based on switched 
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ACELP and transform coded excitation (TCX). In ACELP mode, the standard AMR-WB codec is used. The HE signal 
is encoded with relatively few bits using a bandwidth extension (BWE) method. 

The parameters transmitted from encoder to decoder are the mode selection bits, the LE parameters and the HE 
parameters. The parameters for each 1024-sample super-frame are decomposed into four packets of identical size. 

When the input signal is stereo, the Left and right channels are combined into mono signal for ACELP/TCX encoding, 
whereas the stereo encoding receives both input channels. 

Eigure 2 presents the AMR-WB + decoder structure. The LE and HE bands are decoded separately after which they are 
combined in a synthesis filterbank. If the output is restricted to mono only, the stereo parameters are omitted and the 
decoder operates in mono mode. 
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Figure 1: High-level structure of AMR-WB+ encoder 



DEMUX 



HF parameters 



HF parameters 



mode 



Mono 
LF parameters 



Stereo 
parameters 



HF decoding 



HF decoding 



ACELP/TCX 
decoding 



Stereo 
decoding 



HF signals folded in 
p^^ O-Fs/4 kHz band 



Mhf 
Mlf 



Rli 



synthesis 
filterbank and 
postprocesing 



Output signa l 



Output signa l 



Output signal 
M "^ 



Mono operation 

Figure 2: High-level structure of AMR-WB+ decoder 
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4.3.2 LP analysis and synthesis in low-frequency band 

The AMR-WB+ codec applies LP analysis for both the ACELP and TCX modes when encoding the LF signal. The LP 
coefficients are interpolated linearly at every 64-sample sub-frame. The LP analysis window is a half-cosine of length 
384 samples. 

4.3.3 ACELP and TCX coding 

To encode the core mono signal (O-Fs/4 kHz band), the AMR-WB+ codec utilises either ACELP or TCX coding for 
each frame. The coding mode is selected based on closed-loop analysis-by-synthesis method. Only 256-sample frames 
are considered for ACELP frames (as in AMR-WB), whereas frames of 256, 512 or 1024 samples are possible in TCX 
mode. 

ACELP encoding and decoding are similar to standard AMR-WB speech codec. The ACELP coding consists of LTP 
analysis and synthesis and algebraic codebook excitation. The ACELP coding mode is used in AMR-WB operation 
within AMR-WB + codec. 

In TCX mode the perceptually weighted signal is processed in the transform domain. The Fourier transformed weighted 
signal is quantised using split multi-rate lattice quantisation (algebraic VQ). Transform is calculated in 1024, 512 or 256 
samples windows. The excitation signal is recovered by inverse filtering the quantised weighted signal through the 
inverse weighting filter (same weighting filter as in AMR-WB). 

4.3.4 Coding of high-frequency band 

Whereas the LF signal (O-Fs/4 kHz band) is encoded using the previously described switched ACELP/TCX encoding 
approach, the HE signal is encoded using a low-rate parametric bandwidth extension (BWE) approach. Only gains and 
spectral envelope information are transmitted in the BWE approach used to encode the HE signal. 

The bandwidth extension is done separately for left and right channel in stereo operation. 



4.3.5 Stereo coding 



In the case of stereo coding, a similar band decomposition as in the mono case is used. The two channels L and R are 
decomposed into LF and HE signals. The LF signals of the two channels are down-mixed to form an LF mono signal, 
(O-Fs/4 kHz band). This mono signal is encoded separately by the core codec. 

The LF part of the two channels is further decomposed into two bands (0-5Fs/128 kHz band) and (5Fs/128 kHz- Fs/4 
kHz band). The very low frequency (VLF) band is critically down-sampled, and the side signal is computed. The 
resulting signal is semi-parametrically encoded in the frequency domain using the algebraic VQ. The frequency domain 
encoding is performed in closed loop by choosing among 40-, 80- and 160-sample frame lengths. 

The high frequency part of the LF signals (Midband) are parametrically encoded. In the decoder, the parametric model 
is applied on the mono signal excitation in order to restore the high frequency part of the original LF part of the two 
channels. 

The HE part of the two channels are encoded by using parametric BWE described below. 

4.3.6 Low complexity operation 

In the low complexity operation (use case B) the decision on the usage of ACELP and TCX mode is done in an open- 
loop manner. This approach introduces computational savings in the encoder. 

4.3.7 Frame erasure concealment 

When missing packets occur at the receiver, the decoder applies concealment. The concealment algorithm depends on 
the mode of the correctly received packets preceding and following the missing packet. Concealment uses either time- 
domain coefficient extrapolation, as in AMR-WB, or frequency-domain interpolation for some of the TCX modes. 
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4.3.8 Bit allocation 

The bit allocation for the different parameters in the low-frequency band coding (Core) (O-Fs/4 kHz band) is shown in 
Tables 3, 4, 5, and 6. Note that there are two mode bits sent in each 256-sample packet. These mode bits are not shown 
in the bit allocation tables. The bit allocations for the stereo part is shown in Tables 7, 8, and 9. Note that there are also 
two additional mode bits for the VLF stereo encoder, which are not shown in the bit allocation. The bit allocation for 
the stereo HF part is by definition that of the bandwidth extension, as presented in Tables 7,8 and 9. 

Tables 2 and 3 show the total bits per 256-sample packet, including mode bits. 

Table 3: Bit allocations for ACELP core rates including BWE (per frame) 



Parameter 


Number of bits 


Mode bits 


2 


ISF Parameters 


46 


Mean Energy 


2 


Pitch Lag 


30 


Pitch Filter 


4x 1 


Fixed-codebook 
Indices 


4x20 


4x28 


4x36 


4x44 


4x52 


4x64 


4x72 


4x88 


Codebook Gains 


4x7 


HF ISF Parameters 


9 


HFgain 


7 


Total in bits 


208 


240 


272 


304 1 336 1 384 


416 


480 


Table 4: Bit allocations for 256-sample TCX window (Core) 


Parameter 


Number of bits 


Mode bits 


2 


ISF Parameters 


46 


Noise factor 


3 


Global Gain 


7 


Algebraic VQ 


134 


166 


198 


230 


262 


310 


342 


406 


HF ISF Parameters 


9 


HFgain 


7 


Total in bits 


208 


240 


272 


304 1 336 1 384 


416 


480 


Table 5: Bit allocations for 512-sample TCX window (Core) 


Parameter 


Number of bits 


Mode bits 


2+2 


ISF Parameters 


46 


Noise factor 


3 


Global Gain 


7 


Gain redundancy 


6 


Algebraic VQ 


318 


382 


446 


510 1 574 1 670 


734 


862 


HF ISF Parameters 


9 


HFgain 


7 


HF Gain correction 


8x2 


Total in bits 


416 


480 


544 


608 


672 


768 


832 


960 
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Table 6: Bit allocations for 1024-sample TCX window (Core) 



Parameter 


Number of bits 


Mode bits 


2+2+2+2 


ISF Parameters 


46 


Noise factor 


3 


Global Gain 


7 


Gain redundancy 


3+3+3 


Algebraic VQ 


695 1 823 1 951 | 1079 | 1207 | 1399 | 1527 | 1783 


HF ISF Parameters 


9 


HFgain 


7 


HF Gain correction 


16x3 


Total in bits 


832 1 960 1 1088 | 1216 | 1344 | 1536 | 1664 | 1920 



Table 7 Bit allocations for stereo encoder for 256-sample window 



Parameter 


Number of bits 


Mode bits 


2 


Global Gain 


7 


Gain 


7 


Unused bits 


1 


Midband 


6 


12 


Algebraic VQ 


1 


9 


17 


25 


33 


41 


49 


51 1 59 1 67 


75 


83 


91 


99 


107 


115 


HF ISF Parameters 


9 


HFgain 


7 


Total in bits 


40 


48 


56 


64 


72 


80 


88 1 96 1 104 1 112 


120 


128 


136 


144 


152 


160 



Table 8 Bit allocations for stereo encoder for 512-sample window 



Parameter 


Number of bits 


Mode bits 


2+2 


Global Gain 


7 


Gain 


7 


Unused bits 


1+1 


Midband 


6x2 


12x2 


Algebraic 
VQ 


16 


32 


48 


64 


80 


96 


112 


116 


132 


148 


164 


180 


196 


212 


228 


244 


HFISF 
Parameters 


9 


HFgain 


7 


HFGain 
correction 


8x2 


Total in bits 


80 96 112 128 144 160 176 192 208 224 240 256 272 288 304 320 



Table 9 Bit allocations for stereo encoder for 1024-sample window 



Parameter 


Number of bits 


Mode bits 


2+2+2+2 


Global 
Gain 


7 


Gain 


7 


Unused 
bits 


1+1+1+1 


Midband 


6x4 


12x4 


Algebraic 
VQ 


46 


78 


110 


142 


174 


206 


238 


246 


278 


310 


342 


374 


406 


438 


470 


502 


HFISF 
Parameters 


9 


HFgain 


7 


HFGain 
correction 


16x3 


Total in bits 


160 1 192 1 224 1 256 | 288 | 320 | 352 | 384 | 416 | 448 | 480 | 512 | 544 | 576 | 608 | 640 
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5 Functional description of the encoder 

In this clause, the different functions of the encoder extension modes represented in Figure 1 are described. Input 
signals are understood as internal, i.e. sampled at the internal sampling frequency Fs. 



5.1 Input signal pre-processing 



Input signals are pre-processed in order to bring them to the internal sampling frequency of the encoder Fs kHz. The 
signal is upsampled by a factor K (related to the desired internal sampling frequency), filtered by a a low pass filter and 
then downsampled by a factor 180. This operation is efficiently implemented by a polyphase filter implementation. 



tK 



Input signal 180Fs/KkHz 



LP 
1/180 



i180 



Output signal Fs kHz 



The resulting signals are further decomposed into two equal critically sampled bands as shown in the following figure: 





HP 
LP 




4.2 
12 




Input signal Fs kHz 
2048 samples 




1024 samples 








1024 samples 



At an internal sampling rate of Fs kHz, the lower band signals are obtained by first low-pass filtering to Fs/4 kHz 
critically downsampling the low-pass filtered signal to Fs/2 kHz. The higher band signals are obtained by band-pass 
filtering the input signals to frequencies above Fs/4 kHz, and critically downsampling the high-pass filtered signal to 
Fs/2kHz sampling frequency. 



5.1 .1 High Pass Filtering 

The lower band signals are high pass filtered. The high-pass filter serves as a precaution against undesired low 
frequency components. A high pass filter is used, and it is given by 



HM) = 



_\-h,z~'+h^z~ 



l-a^z ^ +^2^ ^ 



where the filter parameters are dependent on the internal sampling rate. 

5.1 .2 Stereo Signal Downmixing/Bandsplitting 

When the input audio signal is stereo, the lower band mono signal is obtained by downmixing the left and right 
channels according to the following 

where X^^ (n) , resp. X^^ (n) , is the lower band signal from the left, resp. right, channels. The lower band mono signal 
is supplied to the core low band encoder for TCX/ACELP encoding. 
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For stereo encoding, the obtained downmixed mono signal X^^ (n) and the right channel signal X^^ (n) are further 

split into two bands: a critically sampled low frequency band and a residual high frequency band according to the 
following diagram 
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The critically sampled low band output signals, x^^^ {n) and x^^^ {n) are fed to the stereo low band encoder, while 
the signals x^j^-^ (n) and x^^-^ (n) to the stereo mid band encoder. 

5.2 Principle of the hybrid ACELP/TCX core encoding 

The encoding algorithm at the core of the AMR-WB+ codec is based on a hybrid ACELP/TCX model. For every block 
of input signal, the encoder decides (either in open-loop or closed-loop) which encoding model (ACELP or TCX) is 
best. The ACELP model is a time-domain, predictive encoder, best suited for speech and transient signals. The AMR- 
WB encoder is used in ACELP modes. Alternatively, the TCX model is a transform-based encoder, and is more 
appropriate for typical music samples. Frame lengths of variable sizes are possible in TCX mode, as will be explained 
in Section 5.2. L 

In Sections 5.2.1 to 5.2.4, the general principles of the hybrid ACELP/TCX core encoder will be presented. Then 
Section 5.3 and its subsections will give the details of the ACELP and TCX encoding modes. 

5.2.1 Tinning chart of tine ACELP and TCX modes 

The ACELP/TCX core encoder takes a mono signal as input, at a sampling frequency of Fs/2 kHz. This signal is 
processed in super- frames of 1024 samples in duration. Within each 1024-sample super- frame, several encoding modes 
are possible, depending on the signal structure. These modes are: 256-sample ACELP, 256-sample TCX, 512-sample 
TCX and 1024-sample TCX. These encoding modes will be described further, but first we look at the different possible 
mode combinations, described by a timing chart. 

Figure 4 shows the timing chart of all possible modes within an 1024-sample superframe. As the figure shows, each 
256-sample frame within a super-frame can be into one of four possible modes, which we call ACELP, TCX256, 
TCX512 and TCX1024. When in ACELP mode, the corresponding 256-sample frame is encoded with AMR-WB. In 
TCX256 mode, the frame is encoded using TCX with a 256-sample support, plus 32 samples of look-ahead used for 
overlap-and add since TCX is a transform coding approach. The TCX512 mode means that two consecutive 256-sample 
frames are grouped to be encoded as a single 512-sample block, using TCX with a 512-sample support plus 64 samples 
look-ahead. Note that the TCX512 mode is only allowed by grouping either the first two 256-sample frames of the 
super- frame, or the last two 256-sample frames. Finally, the TCX 1024 mode indicates that all 256-sample frames within 
the super- frame are grouped together to be encoded in a single block using TCX with an 1024-sample support plus 128 
samples look-ahead. 
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ACELP(256sanples) 



TCX(256f32sanples) 



ACELP(256sanples) 



ACELP(256sanples) 



TCX(256f32sanples) 



TCX(256f32sanples) 



TCX(512-+6^sanples) 



TCX (1024+128 sanples) 



J \ \ \ \ \ L 



J I I \ I L_L 



32 sanples 



256 sanples 



J \ \ \ I L_L 



64 sanples 



ACELP (256 sanples) 



TCX (256f 32 sanples) 



TCX (512-+M sanples) 



-\ \ \ \ \ \ L 



32 sanples 



256 sanples 



-►-^ 



512 sanples 



512 sanples 



64 sanples 



128 sanples 



1024 sanples 



Figure 4: Timing chart of the frame types 



5.2.2 ACELP/TCX mode combinations and mode encoding 

From Figure 4, there are exactly 26 different ACELP/TCX mode combinations within an 1024-sample superframe. 
These are shown in Table 10. 

Table 10: Possible mode combinations in an 1024-sample super-frame 



(0, 0, 0, 0) 


(0,0,0, 1) 


(2, 2, 0, 0) 




(1,0,0,0) 


(1,0,0,1) 


(2,2,1,0) 




(0, 1,0,0) 


(0, 1,0, 1) 


(2,2,0, 1) 




(1,1,0,0) 


(1,1,0,1) 


(2,2, 1, 1) 




(0,0, 1,0) 


(0,0, 1, 1) 


(0, 0, 2, 2) 




(1,0, 1,0) 


(1,0,1,1) 


(1,0,2,2) 




(0,1,1,0) 


(0,1,1,1) 


(0,1,2,2) 


(2, 2, 2, 2) 


(1,1,1,0) 


(1,1,1,1) 


(1, 1,2, 2) 


(3, 3, 3, 3) 



We interpret each quadruplet of numbers (mo, mi, m2, m^) in Table 10 as follows: my, is the mode indication for the k^ 
256-sample frame in the 1024-sample super- frame, where m^ can take the following values: 

- mk = means the mode for frame k is 256-sample ACELP 
mk = 1 means the mode for frame k is 256-sample TCX 

- mk = 2 means the mode for frame k is 5 12-sample TCX 
mk = 3 means the mode for frame k is 1024-sample TCX 
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Obviously, when the first 256-sample frame is in mode "2" (512-sample TCX), the second 256-sample frame must also 
be in mode 2. Similarly, when the third 256-sample frame is in mode "2" (512-sample TCX), the fourth 256-sample 
frame must also be in mode 2. And there is only one possible mode configuration including the value "3" (1024-sample 
TCX), namely all four 256-sample frames are in the same mode (m^ = 3 for ^ = 0, 1,2 and 3). This rigid frame structure 
can be exploited to aid in frame erasure concealment. 

As discussed above, the parameters for each 1024-sample super- frame are actually decomposed into four frames of 
identical size. To increase robustness, the mode bits are actually sent as two bits (the values of m^) in each transmitted 
frame. For example, if the superframe is encoded in a full 1024-sample TCX frame, which is then decomposed into four 
packets of equal size, then each of these four packets will contain the binary value "11" (mode m^ = 3) as mode 
indicator. 

5.2.3 ACELP/TCX closed-loop mode selection 

The best mode combination out of the 26 possible combinations of Table 10 is determined in closed-loop. This means 
that the signal in each 256-sample frame within an 1024-sample super-frame has to be encoded in several modes before 
selecting the best combination. This closed-loop approach is explained in Figure 5. 

The left portion of Figure 5 (Trials) shows what encoding mode is applied to each 256-sample frame in 11 successive 
trials. FrO to Fr3 refer to Frame to Frame 3 in the super-frame. The trial number (1 to 11) indicates a step in the 
closed-loop mode-selection process. Note that each 256-sample frame is involved in only four of the 1 1 encoding trials. 
When more than 1 frame is involved in a trial (lines 5, 10 and 11 of Figure 5), then TCX of the corresponding length is 
applied (TCX512 or TCX 1024). The right portion of Figure 5 gives an example of mode selection, where the final 
decision (after Trial 11) is 1024-sample TCX. This would result in sending a value of 3 for the mode in all four packets 
for this super-frame. Bold numbers in the example at the right of Figure 5 show at what point a mode decision is taken 
in the intermediate steps of the mode selection process. The final mode decision is only known after Trial 11. 

The mode selection process shown in Figure 5 proceeds as follows. First, in trials 1 and 2, ACELP (AMR-WB) then 
256-sample TCX encoding are tried in the first 256-sample frame (FrO). Then, a mode selection is made for FrO 
between these two modes. The selection criterion is the average segmental SNR between the weighted speech Xy^(n) and 

the synthesized weighted speech x^ (n) . The segmental SNR in subframe / is defined as 



segSNR. = 20 log 



10 



ly — i 



n=0 



N-l 



2 

V«=o J 



Y,{^Jri)-xJn)f 



where N is the length of the subframe (equivalent to a 64-sample sub-frame in the encoder). Then, the average 
segmental SNR is defined as 



1 NsF-l 

segSNR = ^ segSNR, 

iV r 



' SF i=0 

where Nsf is the number of subframes in the frame. Since a frame can be either 256, 512 or 1024 samples in length, Nsf 
can be either 4, 8 or 16. In the example of Figure 5, we assume that, according to the segSNR decision criterion, mode 
ACELP was retained over TCX. Then, in trials 3 and 4, the same mode comparison is made for Frl between ACELP 
and 256-sample TCX. Here, we assume that 256-sample TCX was better than ACELP, based again on the segmental 
SNR measure described above. This choice is indicated in bold on line 4 of the example at the right of Figure 5. Then, 
in trial 5, FrO and Frl are grouped together to form a 512-sample frame which is encoded using 512-sample TCX. The 
algorithm now has to choose between 512-sample TCX for the first 2 frames, compared to ACELP in the first frame 
and TCX256 in the second frame. In this example, on line 5 in bold, the sequence ACELP-TCX256 was selected over 
TCX-512, according to the segmental SNR criterion. 
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FrO 



TRIALS (11) 
Fr 1 Fr 2 



Fr3 



Example of selection 

(in bold = comparison is made) 

FrO Fri Fr2 Fr3 



1 


ACELP 








2 


TCX256 








3 




ACELP 






4 




TCX256 






5 


TCX512 


TCX512 






6 






ACELP 




7 






TCX256 




8 








ACELP 


9 








TCX256 


10 






TCX512 


TCX512 


11 


TCX1024 


TCX1024 


TCX1024 


TCX1024 



ACELP 








ACELP 








ACELP 


ACELP 






ACELP 


TCX256 






ACELP 


TCX256 






ACELP 


TCX256 


ACELP 




ACELP 


TCX256 


TCX256 




ACELP 


TCX256 


TCX256 


ACELP 


ACELP 


TCX256 


TCX256 


TCX256 


ACELP 


TCX256 


TCX512 


TCX512 


TCX1024 


TCX1024X 


TCX1024 


TCX1024 



Figure 5: Closed-loop selection of ACELP/TCX mode combination 

The same procedure as trials 1 to 5 is then apphed to the third and fourth frames (Fr2 and Fr3), in trials 6 to 10. After 
trial 10, in the example of Figure 5, the four 256-sample frames are classified as: ACELP for FO, then TCX256 for Fl, 
then TCX512 for F2 and F3 grouped together. A last trial (line 11) is then performed where all four 256-sample frames 
(the whole super- frame) are encoded with 1024-sample TCX. Using the segmental SNR criterion, again with 64-sample 
segments, this is compared with the signal encoded using the mode selection in trial 10. In this example, the final mode 
decision is 1024-sample TCX for the whole frame. The mode bits for each 256-sample frame would then be (3, 3, 3, 3) 
as discussed in Table 10. 

5.2.4 ACELP/TCX open-loop mode selection 

The alternative method for ACELP/TCX mode selection is the low complexity open-loop method. The open-loop mode 
selection is divided into three selection stages: Excitation classification (EC), excitation classification refinement (ECR) 
and TCX selection (TCXS). The mode selection is done purely open-loop manner in EC and ECR. The usage of TCXS 
algorithm depends on EC and ECR and it is closed loop TCX mode selection. 

1. stage 

The first stage excitation classification is done before LP analysis. The EC algorithm is based on the frequency content 
of the input signal using the VAD algorithm filter bank. 

AMR-WB VAD produces signal energy E(n) in the 12 non-uniform bands over the frequency range from to Fs/4 kHz 
for every 256-sample frame. Then energy levels of each band are normalised by dividing the energy level E(n) from 
each band by the width of that band in Hz producing normalised £^(11) energy levels of each band where n is the band 
number from to 11. Index refers to the lowest sub band. 

For each of the 12 bands, the standard deviation of the energy levels is calculated using two windows: a short window 
stdshort(n) and a long window stdiong(n). The length of the short and long window is 4 and 16 frames, respectively. In 
these calculations, the 12 energy levels from the current frame together with past 3 or 15 frames are used to derive two 
stdUshort and stdaiong standard deviation values. The standard deviation calculation is performed only when VAD 
indicates active signal. 

The relation between lower frequency bands and higher frequency bands are calculated in each frame. The energy of 
lower frequency bands LevL from 1 to 7 are normalised by dividing it by the length of these bands in Hz. The higher 
frequency bands 8 to 1 1 are normalised respectively to create LevH. Note that the lowest band is not used in these 
calculations because it usually contains so much energy that it will distort the calculations and make the contributions 
from other bands too small. From these measurements the relation LPH = LevL / LevH is defined. In addition, for each 
frame a moving average LPHa is calculated using the current and 3 past LPH values. The final measurement of the low 
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and high frequency relation LPHaF for the current frame is calculated by using weighted sum of the current and 7 past 
LPHa values by setting slightly more weighting for the latest values. 

The average level {AVL) in the current frame is calculated by subtracting the estimated level of background noise from 
each filter bank level after which the filter bank levels are normalised to balance the high frequency bands containing 
relatively less energy than the lower bands. In addition, total energy of the current frame, TotEg^ is derived from all the 
filter banks subtracted by background noise estimate of the each filter bank. Total energy of previous frame is therefore 
TotE.i. 

After calculating these measurements, a choice between ACELP and TCX excitation is made by using the following 
pseudo-code: 

if {stdaiong < 0.4) 

SET TCX_MODE 
else if (LPHaF > 280) 

SET TCX_MODE 
else if {stdaiong >= 0.4) 
if ((5+(l/( stdaiong -0.4))) > LPHaF) 

SET TCX_MODE 
else if ((-90* stda^ng +120) < LPHaF) 

SET ACELP_MODE 
else 

SET UNCERTAIN_MODE 

if (ACELP_MODE or UNCERTAIN_MODE) and {AVL > 2000) 

SET TCX_MODE 
if (UNCERTAIN_MODE) 
if {stdUshort < 0.2) 

SET TCX_MODE 
else if {stdUshort >= 0.2) 

if ((2.5+(l/( stdashort -0.2))) > LPHaF) 

SET TCX_MODE 
else if ((-90* stdUshort +140) < LPHaF) 

SET ACELP_MODE 
else 

SET UNCERTAIN_MODE 
if (UNCERTAIN_MODE) 
if {{TotEo I TotE.i )>25) 
SET ACELP_MODE 

if (TCX_MODE II UNCERTAIN_MODE)) 
if {AVL > 2000 and TotEo < 60) 
SET ACELP_MODE 
2. stage 

ECR is done after open-loop LTP anlysis. 

If VAD flag is set and mode has been classified in EC algorithm as uncertain mode (defined as TCX_OR_ACELP), the 
is mode is selected as follows: 

if(5D„>0.2) 

Mode = ACELP_MODE; 
else 
ii{LagDifi,uf<2) 

if {Lagn == HIGH LIMIT or Lagn == LOW LIMIT) { 
if {Gainn-NormCorr„<0.l and NormCorr„>0. 9) 
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Mode = ACELP_MODE 
else 

Mode = TCX_MODE 
else if (GaiUn- NormCorrn < 0.1 and NormCorrn > 0.88) 

Mode = ACELP_MODE 
else if (GaiUn - NormCorrn > 0.2) 

Mode = TCX_MODE 
else 

NoMtcx = NoMtcx +1 
if (MaxEnergyifuf < 60 ) 
if(SDn>0A5) 

Mode = ACELP_MODE; 
else 

NoMtcx = NoMtcx +1. 
Where spectral distance, SDn, of the frame n is calculated from ISP parameters as follows: 



SD(n)^Y.\^SP„(i)-ISP„_,ii)\. 



i=0 

where ISPn is the ISP coefficients vector of the frame n and ISPn(i) is /th element of it. 

LagDifbuf is the buffer containing open loop lag values of previous ten frames (256 samples). 

Lagn contains two open loop lag values of the current frame n. 

GaiUn contains two LTP gain values of the current frame n. 

NormCorrn contains two normalised correlation values of the current frame n. 

MaxEnergybufi^ the maximum value of the buffer containing energy values. The energy buffer contains last six values 
of current and previous frames (256 samples). 

Iphn indicates the spectral tilt. 

If VAD flag is set and mode has been classified in EC algorithm as ACELP mode, the mode decision is verified 
according to following algorithm where mode can be switched to TCX mode. 

ii{LagDifbuf<2) 
if {NormCorrn < 0.80 and SDn < 0.1) 
Mode = TCX_MODE; 
if (Iphn > 200 and SDn < 0.1) 
Mode = TCX_MODE 
If VAD flag is set in current frame and VAD flag has set to zero at least one of frames in previous super- frame and the 
mode has been selected as TCX mode, the usage of TCX 1024 is disabled (the flag NoMtcx is set). 

if (vadFlagoid == and vadFlag == 1 and Mode == TCX_MODE)) 
NoMtcx = NoMtcx +1 

If VAD flag is set and mode has been classified as uncertain mode (TCX_OR_ACELP) or TCX mode, the mode 
decision is verified according to following algorithm. 

if {GaiUn - NormCorrn < 0.006 and NormCorrn > 0.92 and Lagn > 21) 
DFTSum = 0; 
for(i=l;i<40;i++) 

DFTSum = DFTSum + mag[i]; 
if (DFTSum > 95 and mag[0] < 5) 

Mode = TCX_MODE; 
else 
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Mode = ACELP_MODE; 
NoMtcx = NoMtcx +1 
vadFlagoidi^ the VAD flag of the previous frame and vadFlag is the VAD flag of the current frame. 

NoMtcx is the flag indicating to avoid TCX transformation with long frame length (1024 samples), if TCX coding 
model is selected. 

Mag is a discete Fourier transformed (DFT) spectral envelope created from LP filter coefficients, Ap, of the current 
frame. DFTSum is the sum of first 40 elements of the vector mag , excluding the first element (mag(O)) of the vector 
mag. 

If VAD flag is set and the mode, Mode(Index), of the Indexth frame of current superframe has still been classified as 
uncertain mode (TCX_OR_ACELP), the mode is decided based on selected modes in the previous and current 
superframes. The counter, TCXCount, gives the number of selected long TCX frames (TCX512 and TCX 1024) in 
previous superframe (1024 samples). The counter, ACELPCount, gives the number of ACELP frames (256 samples) in 
previous and current superframes. 

if ((prevMode(i) == TCX1024 or prevMode(i) == TCX512) and vadFlagoid(i)== 1 and 
TotEi > 60) 

TCXCount = TCXCount + 1 
if (prevMode(i) == ACELP_MODE) 

ACELPCount=ACELPCount + 1 
if (Index != i) 

if (Mode(i) == ACELP_MODE) 
ACELPCount = ACELPCount + 1 
Where prevMode(i) is the ith frame (256 samples) in the previous superframe, Mode(i) is the ith frame in the current 
superframe. / is the frame (256 samples) number in superframe (1, 2, 3, 4), The mode, Mode(Index), is selected based 
on the counters TCXCount mid ACELPCount as follows 

if (TCXCount > 3) 

Mode(Index) = TCX_MODE; 
else if (ACELPCount > 1) 

Mode(Index) = ACELP_MODE 

else 

Mode(Index) = TCX_MODE 
3. stage: TCXS is done only if the number of ACELP modes selected in EC and ECR is less than three (ACELP<3) 
within an 1024-sample super- frame. The Table 11 shows the possible mode combination which can be selected in 
TCXS. TCX mode is selected according to segmental SNR described in Chapter 5.2.3 (ACELP/TCX closed-loop mode 
selection). 

Table 11 : Possible mode combination selected in TCXS 



Selected mode combination 

after open-loop mode 

selection 

(TCX = 1 and ACELP = 0) 


Possible mode combination after TCXS 

(ACELP = 0, TCX256 = 1 , TCX512 = 2 and 

TCX1024 = 3) 






NoMTcx 


(0,1,1,1) 


(0,1,1,1) 


(0,1,2,2) 




(1,0,1,1) 


(1,0,1,1) 


(1,0,2,2) 




(1,1,0,1) 


(1,1,0,1) 


(2,2,0,1) 




(1,1,1,0) 


(1,1,1,0) 


(2,2,1,0) 




(1, 1,0, 0) 


(1, 1,0, 0) 


(2, 2, 0, 0) 




(0,0, 1, 1) 


(0,0,1,1) 


(0, 0, 2, 2) 




(1,1,1,1) 


(1,1,1,1) 


(2, 2, 2, 2) 


1 


(1,1,1,1) 


(2, 2, 2, 2) 


(3, 3, 3, 3) 
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5.3 Hybrid ACELP/TCX core encoding description 

5.3.1 Pre-emphasis 

The input (mono) signal to the core ACELP/TCX encoder is first pre-processed through a high-pass filter. Then, a first- 
order, fixed pre-emphasis filter is applied with transfer function: 

P(z) = l-0.68z-^ 

This pre-emphasis filter reduces the signal energy at low frequency and increases the signal energy at high frequency. 
The result is a signal with a less spectral dynamics, which enhances the resolution of LPC analysis. This is particularly 
important in fixed-point implementations. 

5.3.2 LP analysis and interpolation 

The principles are similar to 3GPP TS 26.190 (Section 5.2) except for the window shape and position, and the 
interpolation factors. 

LPC analysis is performed every 256 samples in the superframe. The analysis window has 448 samples in duration, and 
has the shape of a half-sine cycle. It is symmetrical, and centred, for each LP analysis, at the middle of the first 64- 
sample sub-frame following each 256-sample frame. Hence, the lookahead required for LP analysis is half the analysis 
window length plus 32 samples, for a total of 256 samples. 

The autocorrelations of windowed speech are converted to the LP coefficients using the Levinson-Durbin algorithm. 
Then the LP coefficients are transformed to the ISP domain for quantization and interpolation purposes. The 
interpolated quantized and unquantized filters are converted back to the LP filter coefficients (to construct the synthesis 
and weighting filters at each subframe). 

The LP coefficients are quantized in the ISF domain, and interpolated every 64 samples. Depending on the coding mode 
selected (ACELP or TCX), the LP coefficients are transmitted at different update rates. For ACELP, which is based on 
the AMR-WB encoder, the LP coefficients are transmitted every 256 samples. For TCX, the LPC coefficients are 
transmitted every 256, 512 or 1024 samples, depending on the TCX frame length. 

The LPC analysis is identical for ACELP or TCX. 

5.3.2.1 Windowing and auto-correlation computation 

A 448-sample symmetrical sine window is used. The window is given by 



w(n) = sin 



-(/ + 0.5) 
L J 



/ = 0,...,L-1 



where L=488 is the window length. 



Autocorrelation computation and lag windowing are similar to 3GPP TS 26.190 (Section 5.2.1) with the exception that 
the window length is 488 samples and centred at the middle of the first subframe of the next 256-sample frame. 

5.3.2.2 Levinson-Durbin algorithm 

Same as 3GPPTS 26.190. 

5.3.2.3 LP to ISP conversion 

Same as 3GPPTS 26.190. 

5.3.2.4 ISP to LP conversion 

Same as 3GPPTS 26.190. 
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5.3.2.5 Quantization of the ISP coefficient 

Same as 3GPP TS 26.190. The difference is that the in case of TCX, the LP parameters are quantized and transmitted 
once per TCX frame (256, 512, or 1024 samples). 

5.3.2.6 Interpolation of the ISPs 

Since the LP analysis window shape and position is changed compared to AMR-WB, the interpolation factors have 
changed. 

(n) 

The interpolation is performed on the ISPs in the q domain (cosine domaine). Letq be the ISP vector from LP 

analysis at frame n (centred at the 1^^ subframe of the frame n-\-l), and q " the ISP vector from LP analysis at frame 
n-1 (centred at the 1^^ subframe of the frame n). The interpolated ISP vectors in each subframe are given by 

q«=(l-^)q<''-'>+^q«, / = 0,...,3. 

The interpolated ISP vectors are used to compute a different LP filter at each subframe using the ISP to LP conversion 
method. 

The interpolation is performed for both unquantized and quantized parameters. In case TCX frames, the LP parameters 
are quantized once per 256-sample, 512-sample, or 1024-sample TCX frame, depending on the selected TCX mode. 
Thus the interpolation of quantized ISPs is performed as follows. In case of ACELP or 256-sample TCX frames, the 
interpolated quantized parameters are given by 

q(«)=(l_l)q(«-i)+lq("), / = 0,...,3. 

In case of 512-sample TCX frames, comprised of 256-sample frames n and n-\-l, the interpolated quantized parameters 
are given by 

8 8 

In case of 1024-sample TCX frames, comprised of 256-sample frames n, n-\-l, n+2, and n+3, the interpolated quantized 
parameters are given by 

16 16 

5.3.3 Perceptual weighting 

Same as 3GPP TS 26.190, using a filter of the form W(z) = Mz/rOHje-emphiz) • Note that in case of TCX coding, 
quantized filter coefficients are used at the numerator, so that the filter is given by W(z) = A(z I Yi )H^^_^ r^ (z) . 

5.3.4 ACELP Excitation encoder 

5.3.4.1 Open-loop pitch analysis 

Same as 3GPP TS 26.190 but with the minimum and maximum pitch lags as functions of the internal sampling rate. 

5.3.4.2 Impulse response computation 

Same as 3GPPTS 26.190. 



ETSI 



3GPP TS 26.290 version 9.0.0 Release 9 

5.3.4.3 Target signal computation 

Same as 3GPPTS 26.190 



26 



ETSI TS 126 290 V9.0.0 (2010-01) 



5.3.4.4 Adaptive codebook 

Same as 3GPP TS 26.190 but with the minimum and maximum pitch lags as functions of the internal sampling rate. 



5.3.4.5 



Algebraic codebook 



Same as 3GPP TS 26.190. The codebooks used in some basic core rates are the same as used in AMR-WB at 12.65, 
14.25, 15.85, 18.25, 19.85, and 23.05, respectively. The codebook used in mono rate 208 bits/frame is the same as the 
one used in AMR-WB at 8.85 kbps (20 bit codebook). The codebook used in mono rate 240 bits/frame is a 28 bit 
codebook where two tracks contain one pulse each and two tracks contain two pulses each according to the following 
table: 

Table 12: Potential positions of individual pulses in the 28-bit algebraic codebook 



Track 


Pulse 


Positions 


1 


"0,14 


0, 4, 8, 12, 16, 20, 24, 28, 32 36, 40, 44, 48, 52, 56, 60 


2 


'1, 


1 , 5, 9, 1 3, 1 7, 21 , 25, 29, 33, 37, 41 , 45, 49, 53, 57, 61 


3 


"2,15 


2, 6, 10, 14, 18, 22, 26, 30, 34, 38, 42, 46, 50, 54, 58, 62 


4 


'3, 


3,7,11,15,19, 23, 27, 31 , 35, 39, 43, 47, 51 , 55, 59, 63 



5.3.4.5.1 Codebook structure 

Same as 3GPPTS 26.190. 

5.3.4.5.2 Pulse indexing 

Same as 3GPPTS 26.190. 

5.3.4.5.3 Codebook search 

Same as 3GPPTS 26.190. 



5.3.4.6 



Quantization of the adaptive and fixed codebook gains 



The adaptive codebook gain (pitch gain) and the fixed (algebraic) codebook gain are vector quantized using the same 7- 
bit codebook used in AMR-WB for modes 2 to 8. However, instead of using MA prediction to obtain the predicted gain 
g'c , it is found by directly quantizing the average innovation energy in the whole frame. 

Let Es(n) be the innovation energy (in dB) at subframe n, and given by 



[N ^ 



i=0 



= 20\og(g^) + E, 



where N=64 is the subframe size, c(i) is the fixed codebook excitation, and Ei is the un-scaled innovation energy given 
by 

An estimated innovation energy E^ is computed and quantized, and used to find the estimated gain gV . That is. 
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which is derived from the relation E ^ = 201og(g'^ ) + E. . 

A correction factor between the gain g^ and the estimated one g'c is given by 

The pitch gain, gp, and correction factor y are jointly vector quantized using the same 7-bit codebook used in AMR-WB, 
and using the same error minimization procedure. That is, the gain codebook search is performed by minimizing the 
mean- square of the weighted error between original and reconstructed signal. 

The estimated innovation energy is computed and quantized as follows. First, the LP residual energy is computed in 
each subframe n by 



E^^^in) ^lOlog,, 



1 A^-1 



\N:.„ 



then the average residual energy per subframe is found by 

3 



— 1 

4 «=0 



The innovation energy is estimated from the residual energy by removing an estimate of the adaptive codebook 
contribution. This is done by removing an energy related to the average normalized correlation obtained from the two 
open-loop pitch analyses performed in the frame. That is 

where R is the average of the normalized pitch correlations obtain for each half- frame from the open-loop pitch 
analysis. 

The estimated innovation energy is quantized once per frame using 2 bits, with the quantization levels: 18, 30, 42, and 
54. Further, the quantized estimated innovation energy E^ is constrained to be larger than E^ax-'^^ ^ where E^ax is the 

maximum value ofEresin) from the 4 subframes. This is done by incrementing E^ by 12 (and the quantization index by 

l)until£, >£„,,-37or£, =54. 

The quantized estimated innovation energy is then used to compute the estimated gain in each subframe is explained 
above. 

5.3.5 TCX Excitation encoder 

This section presents the details of the TCX encoder, which is one of the possible modes to encode the mono, low- 
frequency signal in the O-Fs/4 kHz band. Section 5.3.5.1 first presents the block diagram of the TCX encoder. Then, the 
details of each module are given in sections 5.3.5.2 to 5.3.5.13. 

5.3.5.1 TCX encoder block diagram 

Figure 6 shows a block diagram of the TCX encoding mode. The TCX encoding principle is similar for TCX frames of 
256, 512 and 1024 samples, with a few differences mostly involving the windowing and filter interpolation. The input 
audio signal is first filtered through a time- varying weighting filter (same perceptual filter as in AMR-WB) to obtain a 
weighted signal x. The weighting filter coefficients are interpolated in the ISP domain as in Section 5.3.2.6. The 
interpolation is linear, and the beginning and end of the interpolation depend on the refresh rate of the LPC filter. The 
LPC filter is transmitted only once per TCX frame. For longer frames (TCX512 and TCX 1024) the interpolated LPC 
filters will be farther apart that in the case of TCX256 or ACELP frames. 

Continuing in Figure 6, if the past frame was an ACELP frame, the zero-input response (ZIR) of the weighting filter is 
removed from the weighted signal, using the filter state at the end of the previous (ACELP) frame. The signal is then 
windowed (the window shape will be described in section 5.3.5.4) and a transform is applied to the windowed signal. In 
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the transform domain, the signal is first pre-shaped, to minimize coding noise artefact in the low-frequencies, and then 
quantized using a specific lattice quantizer. Specifically, an 8-dimensional multi-rate lattice quantizer is used, based on 
an extension of the Gosset lattice. 

After quantization, the inverse pre-shaping function is applied to the spectrum which is then inverse transformed to 
provide a quantized time-domain signal. The gain for that frame is then rescaled to optimize the correlation with the 
original weighted signal. After gain rescaling, a window is again applied to the quantized signal to minimize the block 
effects due to quantizing in the transform domain. Overlap-and-add is used with the previous frame if it was also in 
TCX mode. Finally, the excitation signal is found through inverse filtering with proper filter memory updating. This 
TCX excitation is in the same "domain" as the ACELP (AMR-WB) excitation. 
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Figure 6: Principle of TCX encoding 

Each module of Figure 6 will now be detailed in the following subsections. 
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5.3.5.2 



Computation of the target signal for transfornn coding 



To obtain the weighted signal, the input frame of audio samples is filtered with a perceptual filter having the following 
transfer function: 



W(z) 



A(z/0.92) 
1-0.68Z"' 



Here, A(z) is the quantized LP filter, interpolated at every 64-sample sub-frame in the ISP domain as in Section 

5.3.2.6, and A(z 1 0.92) is the weighted version of that filter. The denominator of W{z) is a constant polynomial of 
order 1, which is equal to the numerator of the pre-emphasis filter in Section 5.3.1. 



5.3.5.3 



Zero-input response subtraction 



If the previous encoded frame was ACELP, then the zero-input response (ZIR) of the combination of the weighting 
filter and synthesis filter is removed from the weighted signal. The ZIR is truncated to 128 samples and windowed in 
such a way that its amplitude monotonically decreases to zero at after 128 samples. The truncated ZIR is computed 
through the following steps: 

Using the filter states at the end of the previous frame, compute the ZIR of the following transfer function over 2 
consecutive subframes (128 samples duration): 



H{z)^ 



1 A(z 70.92) 
A(z)l-0.68z-^ 



where A{z) and A(z/0.92) are as defined in Section 5.3.5.2. 

Then, calling z{n) the truncated ZIR of H(z) (truncated to the first 2N samples, where N=64 is the subframe length), 
compute Zw(^), the windowed ZIR such that it is always forced to zero at the last sample: 

z^(n) = z(n)^w(n) foYn = to 2*A^-1 

where 

w(n) = I for ^ = to A^-1 

and w(n) = (im-n) I N forn = Nio2m-\ 

The shape of w{n) is shown in Figure 7 below, for a value of A^= 64. 
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Figure 7: Shape of window to truncate the ZIR 
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After computing Zw(^), it is removed from the first 2^N samples of the weighted signal x{n). This removal of the ZIR 
from the past frame is performed only when the past frame was in ACELP mode. 



5.3.5.4 



Windowing of target signal 



In TCX mode, windowing in applied prior to the transform, and after the inverse transform, in order to apply overlap- 
and-add to minimize the framing effects due to quantization. 

To smooth the transition between ACELP and TCX modes, proper care has to be given to windowing and overlap of 
successive frames. Figure 8 shows the window shapes depending on the TCX frame length and the type of the previous 
frame (ACELP of TCX). 
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(c) target windowing in TCX 1024+128 samples 
Figure 8: Target signal windowing in TCX coding 

The window is defined as the concatenation of the following three sub- windows: 
wi{n) = sm(2 nn/ (4 Li)) for^ = 0, ...,Li-l 
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Wjin) = I for 72 = 0, ...,L-Li-1 

W3(n) = sin(2 Kn/(4L2)) for 72 = L2, . . . , 2L2- 1 

The constants Li, L2 and L are defined as follows. 

Li = when the previous frame is a 256-sample ACELP frame 

Li = 32 when the previous frame is a 256-sample TCX frame 

Li = 64 when the previous frame is a 512-sample TCX frame 

Li = 128 when the previous frame is an 1024-sample TCX frame 
Additionally: 

For 256-sample TCX: L = 256 and L2 = 32 

For 512-sample TCX: L = 5 12, and L2 = 64 

For 1024-sample TCX: L = 1024, and L2 = 128 and 

We note again that all these window types are applied to the weighted signal, only when the present frame is a TCX 
frame. Frames of type ACELP are encoded as in AMR-WB encoding (i.e. through analysis-by-synthesis encoding of 
the excitation signal, so as to minimize the error in the target signal - the target signal is essentially the weighted signal 
from which the zero-input response of the weighting filter is removed). 

5.3.5.5 Transform 

After windowing, the signal is mapped to the frequency domain through a Discrete Fourier Transform (DFT), defined 
as: 

1 LTOT-l -j^^nk 

X(k) = - — X ^(^> ""'' 

where Ljot is the number of samples in the DFT. Ljot depends on the frame length (256, 512 or 1024 samples, plus the 
lookahead which is a function of the frame length). 

An EFT is used to accelerate the computation of the Fourier coefficients. A radix-9 EFT is used to adapt to the frame 
length which is not a power of 2. Including the overlap in the windowing described in Section 5.3.5.4, the number of 
samples at the input of the EFT is, respectively, Ljot = 288 for 256-sample TCX frames (256 samples in the frame plus 
32 samples in the look-ahead), Ltot =576 for 512-sample TCX (512 samples in the frame plus 64 samples in the 
lookahead), and Ltot =1 152 samples for 1024-sample TCX (1024 samples in the frame plus 128 samples in the 
lookahead). 

5.3.5.6 Spectrum pre-shaping 

Once the Fourier spectrum (EFT) is computed, an adaptive low-frequency emphasis module is applied to the spectrum, 
to minimize the perceived distortion in the lower frequencies. The inverse low-frequency emphasis will be applied at 
the decoder, as well as in the encoder to allow obtaining the excitation signal necessary to encode the next frames. The 
adaptive low-frequency emphasis is applied only on the first quarter of the spectrum, as follows. 

First, we call X the transformed signal at the output of the transform (EFT) in Figure 6. The Fourier coefficient at 
Nyquist frequency is systematically set to 0. Then, if Ltot is the number of samples in the EFT (Ltot is thus the window 
length), the K= Ltot /2 complex- valued Fourier coefficients are grouped in blocks of four consecutive coefficients, 
forming 8-dimensional real-valued blocks. This block size of 8 is chosen to coincide with the 8-dimensional lattice 
quantizer used for spectral quantization. The energy of each block is computed, up to the first quarter of the spectrum. 
The energy Efnax and position index / of the block with maximum energy are stored. Then, we calculate a factor for each 
8-dimensional block with position index m smaller than /, as follows: 

- calculate the energy E^ of the 8-dimensional block at position index m 

- compute the ratio R^ = E^ax I E^ 
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- compute the value (7?^) ^^^ 

iiRm > 10, then set 7?^ = 10 (maximum gain of 20 dB) 

- also, if7?^>7?^.i then 7?^ = 7? ^.1 

This last condition ensures that the ratio function 7?^ decreases monotonically. Further, limiting the ratio R^ to be 
smaller or equal to 10 means that no spectral components in the low-frequency emphasis function will be modified by 
more than 20 dB. 

After computing the ratio R^ = (E^ax I E^) '^ for all blocks with position index smaller that / (and with the limiting 
conditions described above), we then apply these ratios as a gain for each corresponding block. This has the effect of 
increasing the energy of blocks with relatively low energy compared to the block with maximum energy E^ax- Applying 
this procedure prior to quantization has the effect of shaping the coding noise in the lower band, such that low energy 
components before the first spectral peak will be better encoded. 

5.3.5.7 Split multi-rate lattice VQ 

To quantize the pre-shaped spectrum X of the weighted signal in TCX mode, a method based on lattice quantizers is 
used. Specifically, the spectrum is quantized in 8-dimensional blocks using vector codebooks composed of subsets of 
the Gosset lattice, referred to as the REs lattice (see [6]). All points of a given lattice can be generated from the so-called 
generator matrix G of the lattice, as c = ^ G, where ^ is a line vector with integer values and c is the generated lattice 
point. To form a vector codebook at a given rate, only lattice points inside a sphere (in 8 dimensions) of a given radius 
are taken. Multi-rate codebooks can thus be formed by taking subsets of different radii. 

In lattice quantization, the operation of finding the nearest neighbour of an input vector x among all codebook points is 
reduced to a few simple operations, involving rounding the components of a vector and verifying a few constraints. 
Hence, no exhaustive search is carried out as in stochastic quantization, which uses stored tables. Once the best lattice 
codebook point is determined, further calculations are also necessary to compute the binary index that will be sent to the 
decoder. The larger the components of the input vector x, the more bits will be required to encode the index of its 
nearest neighbour in the lattice codebook. Hence, to remain within a pre-defined bit budget, a gain-shape approach has 
to be used, where the input vector is first scaled down, i.e. divided by a gain which has to be estimated, then quantized 
in the lattice, then scaled up again to produce the quantization result. To reduce computation complexity, the binary 
indices will actually only be calculated if a given TCX mode is retained as the best mode for a frame. 

For simplicity, we let N be the length of the DFT. Since the transform used to obtain X is a Discrete Fourier Transform, 
there are A//2+1 Fourier coefficients including X(N/2) at Nyquist frequency. In the quantization process, coefficient 
X(N/2) is always set to 0, so there are exactly N/2 Fourier coefficients to quantize. Then, all coefficients of X are 
complex, except X(0) which is real. 

To be quantized using the REs lattice codebooks, the pre-shaped spectrum X is split into consecutive blocks of 8 real 
values (4 consecutive complex coefficients). There are K=N/H such blocks in the whole spectrum. We call B^ the k^^ 
block, with k = 0, I, ..., K-l.To remain within the total bit budget, the spectrum X will have to be divided by a global 
gain g prior to quantization, and multiplied by the quantized global gain after each block Bj, is encoded using the REg 
lattice. We call X=X/g the scaled spectrum and B'j, = Bj, / g the k^^ scaled block. Thus, the parameters sent to the 
decoder to encode the TCX spectrum X are the global gain g and the index of the nearest neighbour of each block Bj, 
within the lattice codebook. 

The index of the nearest neighbour in the lattice is actually composed of three parts: 1) a codebook index, which 
essentially represents the bit allocation for each 8-dimensional vector; 2) a vector index, which uniquely identifies a 
lattice vector in a so-called base codebook C; and 3) an extention index k, which is used to extend the base codebook 
when the selected point in the lattice is not in the base codebook C The extension used, called the Voronoi extension, 
will be described in Step 5 below. 

These parameters are encoded using the 5 Steps described below. 

Step 1 Find the energy Ej, of each block Bj,: 



Ej^ = max(2, ^ 5^ [m]Bj^ [m]) 



m=0 



and obtain from Ej, a first estimate of the bit budget using the starting assumption that the global gain g equals 1 (i.e. 
that the spectrum X is quantized without scaling first): 
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/?.(l)=51og2(^) 

The formula for Rk(l) is based on the properties of the underlying REg lattice, and the method used for encoding the 
index of a lattice point selected by the quantizer. These properties and encoding method will be described in Steps 3 and 

5. 

Unless the energy of the frame is very small, the block energies Ej, will be too large to ensure that the total bit 
consumption (sum of all Rk(l)) remains within the total bit budget for the frame. Hence, it is necessary to estimate a 
gain g so that the quantization ofX'=X/g in the REg lattice will produce a set of indices that stay within the bit budget. 
This gain estimation is performed in Step 2. 

Step 2 The estimation of the global gain g for the TCX frame is performed in an iteration, as follows. 

Initialisation: Set/ac = 128, offset = and nbits_max = 0.95*(NB_BITS_ - K) 

Iteration: Do the following block of operations NITER times (here, NITER =10). 

1- offset = offset + fac 



A 

2- nbits=^msix(0,Rk(l)-ojfset) 



k=l 

3- if nbits <= nbits_max, then offset = offset - fac 
fac = f ac / 2 
After the iteration, the global gain is estimated as 

offsetHog^Qil) 



g = io 



10 



The scaled spectrum can then be obtained as X'=X/g. The input to the lattice quantizer described in Step 3 are the 
scaled blocks B'k = B^ / g, each an 8-dimensional vector of real components. The assumption if that the total number of 
bits used to quantize B'k into the lattice codebook will be close to the bit budget. 

Step 3 In this step, each 8-dimensional block 5 '^^ of the scaled spectrum X'=X/g is rounded as a point in the REg 
lattice, to produce its quantized version, X' . Before looking at the quantization procedure, it is worthwhile 
to look at the properties of this lattice. REg is defined as follows: 

REs=2Dsu{2DsHl,',l)} 

that is as the union of the 2D^ lattice and a version of 2D^ shifted by the vector (1,1,1,1,1,1,1,1). 
Therefore, searching for the nearest neighbour in the lattice REg is equivalent to searching for the nearest 
neighbour in the lattice 2D^, then searching for the nearest neighbour in the lattice 2D^ + (1,1,1,1,1,1,1,1), 
and finally selecting the best of those two lattice points. The lattice 2D^ is just the D^ lattice scaled by a 
factor of 2, with the D^ lattice defined as: 



^8 = b 



Xj , • • • , Xg ) E Z I Xj H h Xg is even] 

That is, the lattice points in D^ are all integers, with the constraint that the sum of all components is even. 
This also implies that the sum of the components of a lattice point in 2D^ is an integer multiple of 4. 

From this definition of REg, it is straightforward to develop a fast algorithm to search for the nearest 
neighbour of an 8-dimensional block 5'^ among all lattice points in REg. This is done by applying the 
following operations. We note that the components of B'j, are floating point values. The result of the 

quantization, B\ , will be a vector of integers. 

7. Zk = 0.5*5', 

2. Round each component of Zk to the nearest integer, to generate Zk 
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3. yli, = 2zk 

4. calculate S as the sum of the components ofyl^ 

5. If 5" is not an integer multiple of 4 (negative values are possible), then modify one of its components as 
follows: 

- find the position / where abs(zk(0- jlk(O) is the highest 

- if zM- yh(I) < 0, then yUD = yh(I) - 2 

- if Zk(/)- yh(I) > 0, then yh(I) = yh(I) + 2 

6. Zk = 0.5 ^ (B'k - 1.0) where 1.0 denotes a vector with all I's 

7. Round each component of Zk to the nearest integer, to generate Zk 

8. y2k = 2zk 

9. calculate S as the sum of the components of j2k 

10. If 5" is not an integer multiple of 4 (negative values are possible), then modify one of its components as 
follows: 

- find the position / where abs(zk(0- y2k(i)) is the highest 

- if Zk(/)- y2k(I) < 0, then y2k(I) = y2k(I) - 2 

- if Zk(/)- y2k(I) > 0, then y2k(I) = y2k{T) + 2 
77.j2k = j2k+1.0 

12. Compute ^Ik = {B'k - yl^)^ and ^2k = {B'k - y2k)^ 

13. If ^ Ik > ^2k, then the best lattice point (nearest neighbour in the lattice) is jlk 
otherwise the best lattice point is 3;2k . 

This is noted as B\—Ck where c^ is the best lattice point as selected above. 

Through this quantization procedure, the scaling gain g, estimated in Step 2, is left unquantized. The gain 
will be quantized only after being recomputed as in Section 5.3.5.10, to obtain g . The quantized 

spectrum will then be obtained as X = gX ' . 

We note that after this lattice quantization step, the indices of the selected lattice points are not known. 
The indices will only be computed if a particular TCX mode is selected instead of an ACELP mode. (See 
Step 5 for the lattice index computation) 

Step 4 A last step in the quantization procedure is the determination and quantization of a comfort noise factor. 
Comfort noise enhances the perceived quality in transform-based coders, which is the case for the TCX 
modes. Comfort noise will be added only to unquantized spectral components in the upper-half of the 
spectrum (Fs/8 kHz and above). Taking again K as the total number of 8-dimensional blocks in the 
spectrum, the comfort noise factor is calculated as follows: 

Initialisation: Set nbits = 0,^=1 and take the ojfset value at the end of the iteration in Step 2 above. 

Iteration : ¥ork = K/2 to ^-1, do 

1 tmp = Rk(l) - offset ( with Rk(l) as calculated in Step 1) 

2. if (tmp < 5), then nbits = nbits + tmp and n = n -\- 1 
Noise factor calculation: 

Set nbits = nbits/ n, and evaluate the noise factor as 
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(nbits-5)nog^Q(2) 

Noise _ factor = 10 ^^ 
The noise factor will be comprised between and 1 . 
Noise level quantization 

The comfort noise factor is quantized using 3 bits in the range from 0.8 to 1.0. 

Step 5 In Step 3, each scaled block 5 '^^ was rounded as a point in the REg lattice. The result is c^ — B\ , the 

quantized version oiB\. If the corresponding TCX mode is actually retained as the best encoding mode 
for that frame (in open-loop fashion as in Section 5.2.4 or in closed-loop fashion as in Section 5.2.3), then 

an index has to be computed for each c^ for transmission to the decoder. The computation of these 

indices is described in this final Step. 

The calculation of an index for a given point in the REg lattice is based on two basic principles: 



1- All points in the lattice REg lie on concentric spheres of radius v8m with m = 0, 1, 2, 3, etc., and 
each lattice point on a given sphere can be generated by permuting the coordinates of reference 
points called leaders. There are very few leaders on a sphere, compared to the total number of 
lattice points which lie on the sphere. Codebooks of different bit rates can be constructed by 
including only spheres up to a given number m. See reference [6] for more details, where 
codebooks Qq, Qi, Q2, Q3, Q4, and Q5 are constructed with respectively 0, 4, 8, 12, 16 and 20 bits. 
Hence, codebook Q^ requires 4n bits to index any point in that codebook. 

2- From a base codebook C (i.e. a codebook containing all lattice points from a given set of spheres 
up to a number m), an extended codebook can be generated by multiplying the elements of C by a 
factor M, and adding a second-stage codebook called the Voronoi extension. This construction is 
given hyy = Mz + v, where M is the scale factor, z is a point in the base codebook and v is the 
Voronoi extension. The extension is computed in such a way that any point y = M z + vis also a 
lattice point in REg. The extended codebook includes lattice points that extend further out from the 
origin than the base codebook. 

The base codebook C in the present TCX modes can be either codebook Qq, Q2, Q3 or Q4 from reference 
[6]. When a given lattice point Ck is not included in these base codebooks, the Voronoi extension is 
applied, using this time only the Q3 or Q4 part of the base codebook. Note that here, Q2 CZ Q^ but Q3 Ct 

24. 

Then, the calculation of the index for each lattice point Ck (quantization result in Step 3) is done 
according to the following operations. 

Verify if Ck is in the base codebook C. Here, this implies verifying if c^ is an element of Qq, 

Qi^ Q3 or Q4 from [6] . If j is in C, the index used to encode C^ is thus the codebook number 

rij^ plus the index 4 of code vector c^ in 2„ ^ . The codebook number rij^ is encoded as a unary 
code, as follows: 

Qo -^ unary code for rij^ is 
Q2 -^ unary code for fZ^ is 10 
Q3 -^ unary code for fZ^ is 110 

Q4 -^ unary code for fZ^ is 1110 

The terminating "0" in this unary code will indicate to the decoder the separation between the successive 
blocks Cj^ in the bit stream. 
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The index 4 indicates the rank of C^ , i.e. the permutation to be appHed to a specific leader to obtain c^ 
(see [6]). Note that if rij^ = 0, then 4 uses no bits. Otherwise, the index 4 uses 4 rij^ bits. Hence, a total of 
5 rij^ bits are required to index any lattice point in the base codebook: rij^ bits for the unary code 
specifying the codebook number (with the exception that 1 bit is required for Qo), and 4 rij^ bits to index 
the lattice point Ck in that codebook. 

If Ck is not in the base codebook, then apply the Voronoi extension through the following sub-steps, using 
this time only Qi, or Q4 as the base codebook. 

VO Set the extension order r= I and the scale factor M =2'' = 2. 

VI Compute the Voronoi index k of the lattice point C^ . The Voronoi index k depends on the 

extension order r and the scale factor M. The Voronoi index is computed via modulo operations 
such that k depends only on the relative position of C^ in a scaled and translated Voronoi region: 

k = mod^ (c^G~') 

Here, G is the generator matrix and mod^(-) is the component- wise modulo-M operation. Hence, 
the Voronoi index ^ is a vector of integers with each component comprised in the interval to M- 
1. 

V2 Compute the Voronoi codevector v from the Voronoi index k. This can be implemented using an 
algorithm described in [7]. 

V3 Compute the difference vector w= C^ - v. This difference vector w always belongs to the scaled 

lattice mA, where A is the lattice REg. Compute z = w/M, i.e., apply the inverse scaling to the 
difference vector w. The codevector z belongs to the lattice A, since w belongs to MA. 

V4 Verify if z is in the base codebook C (i.e. in ^3 or Q4) 

If z is not in C, increment the extension order r by 1, multiply the scale factor M by 2, and go back 
to sub- step VI. 

Otherwise, if z is in C, then we have found an extension order r and a scaling factor M =2'' 

sufficiently large to encode the index of C^ . The index is formed of three parts: 1) the 

codebook index rik as a unary code defined below; 2) the rank 4 of z in the corresponding base 
codebook (either Qi, or Q4); and 3) the 8 indices of the Voronoi index vector k calculated in 
sub-step VI, where each index requires exactly r bits (r is the Voronoi extension order set in 
sub-step VO). 

The codebook index Uj, is encoded in unary code as follows: 

Hk =11110 when the base codebook is Q^ 

and the Voronoi extension order is r = 1 

Hk =111110 when the base codebook is Q4 

and the Voronoi extension order is r = 1 

Hk =1111110 when the base codebook is Q3 

and the Voronoi extension order is r = 2 

Hk =11111110 when the base codebook is Q5 

and the Voronoi extension order is r = 2 

etc. 
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The lattice point C^ is then described as 

Cj^ = M z + v 
The packetisation of these indices into transmission packets will be described in Section 5.6.1. 

5.3.5.8 Spectrum de-shaping 

Spectrum de-shaping is applied to the quantized spectrum prior to applying the inverse FFT. The de-shaping is done 
according to the following steps: 

- calculate the energy E^ of the 8-dimensional block at position index m 

- compute the ratio R^ = E^ax I Em 

- compute the value (Rm) "^ 

- if Rm> 10, then set R^ = 10 (maximum gain of 20 dB) 

- also, if Rm > Rm-i then Rm = R m-\ 

After computing the ratio R^ = (E^ax / ^ m) ' ' for all blocks with position index smaller that / (and with the limiting 
conditions described above), we then divide each block by the corresponding ratio. Note that if we neglect the effects of 
quantization, this de-shaping is the inverse of the pre-shaping function as applied in Section 5.3.5.6. 

5.3.5.9 Inverse transform 

The quantized spectrum X(k) is inverse transformed to obtain the time-domain quantized signal x(n) . The Inverse 
DFT is applied, as defined by: 

^OT ~1 j nk 

where Ljot is the number of samples in the TCX frame, as defined in Section 5.3.5.5. An Inverse FFT is used to 
optimize the computation time of the inverse DFT. 

5.3.5.10 Gain optimization and quantization 

The global gain estimated in Section 5.3.5.7 to scale the spectrum prior to the multi-rate lattice quantization is not 
guaranteed to maximize the correlation between the original weighted signal x and the quantized weighted signal X . 
Thus, after the inverse transform of the quantized spectrum (Section 5.3.5.9), the optimal gain between x and X is 
computed as follows: 

J^x(n)x(n) 

s*-if^, 

'- TOT ^ 

Y^x{n)x{n) 

with Ltot as defined previously. Then, the gain g* is quantized on a logarithmic scale to a 7-bit index, using the 
following procedure. The procedure is purely algebraic and does not require storing a gain codebook. 

2 



1. Calculate the energy of the quantized weighted signal: ^ — /, x(n) 



n=0 



2. Compute the RMS value: rms = 4 (known also at the decoder) 

V ^TOT 
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3. Set G = g^Xrms (normalization step) 

4. Calculate the index as index — |_28 log^^ (G) + 0.5 J where \_x\ denotes removing the fractional part of x 
(rounding towards 0). 

5. If index < 0, then set index =0, and if index >127, then set index =127. 

The quantized gain g * can be calculated as follows, both as the encoder and decoder since the decoder can calculate 
locally the value of rms: 

index 
Q^ — 1 Q28*rm^ 

5.3.5.1 1 Windowing for overlap-and-add 

After gain scaling, the quantized weighted signal is windowed again, according to the TCX frame length and the mode 
of the previous frame. The window shapes are as shown in Figure 8 and defined in Section 5.3.5.4. 

To reconstruct the complete quantized weighted signal, overlap-and-add is applied between the memory of the past 
frame and the beginning of the present frame corresponding to the non-flat portion of the window. Recall that if the past 
frame was in ACELP mode, the memory of the past frame corresponds to the windowed, truncated ZIR of the 
perceptual filter, as calculated in Section 5.3.5.3. 

5.3.5.12 Memory update 

The samples in the lookahead (windowed portion to the right of the TCX frames in Figure 8) are kept in memory for the 
overlap-and-app procedure in the next TCX frame. 

5.3.5.13 Excitation signal computation 

The excitation signal is finally computed by filtering the quantized weighted signal through the inverse weighting filter 
with zero-memory. The excitation is needed at the encoder in particular to update the long-term predictor memory. 

5.4 Mono Signal High-Band encoding (BWE) 

The encoding of the HF signal is detailed in Figure 9. The HF signal is composed of the frequency components above 
Fs/4 kHz in the input signal. The bandwidth of this HF signal depends on the input signal sampling rate. To encode the 
HF signal at a low rate, a bandwidth extension (BWE) approach is employed. In BWE, energy information is sent to the 
decoder in the form of spectral envelope and frame energy, but the fine structure of the signal is extrapolated at the 
decoder from the received (decoded) excitation signal in the LF signal. 

The down-sampled HF signal is called SHpin) in Figure 9. The spectrum of this signal can be seen as a folded version of 
the high-frequency band prior to down-sampling. An LP analysis is performed on SHpin) to obtain a set of coefficients 
which model the spectral envelope of this signal. Typically, fewer parameters are necessary than in the LF signal. Here, 
a filter of order 8 is used. The LP coefficients are then transformed into ISP representation and quantized for 
transmission. The number of LP analysis in an 1024-sample super- frame depends on the frame lengths in the super- 
frame. 
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Figure 9: Higli frequency encoding 

The LP filter for the HF signal is denoted by Ahf{z), and its quantized version is denoted by A hf (z)- From the LF 

signal (s(n) in Figure 9), a residual signal is first obtained by filtering s(n) through the inverse filter A (z). Then, this 

residual is filtered through the quantized HF synthesis filter, 1/ A hf (z)- Up to a gain factor, this produces a good 
approximation of the HF signal, but in a spectrally folded version. The actual HF synthesis signal will be recovered 
when up- sampling is applied to this signal 

Since the excitation is taken from the LF signal, an important step is to compute the proper gain for the HF signal. This 
is done by comparing the energy of the reference HF signal (sHFin)) with the energy of the synthesized HF signal. The 
energy is computed once per 64-sample subframe, with energy match ensured at the Fs/4 kHz subband boundary. 
Specifically, the synthesized HF signal and the reference HF signal are filtered through a perceptual filter derived from 
Ahf{z). The ratio of the energy of these two filtered signals is computed every 64 samples, and expressed in dB. There 
are 4 such gains in a 256-sample frame (one for every 64-sample subframe). This 4-gain vector represents the gain that 
should be applied to the HF signal to properly match the HF signal energy. Instead of transmitting this gain directly, an 

estimated gain ratio is first computed by comparing the gains of filters A (z) from the lower band and A hf (z) from 
the higher band. This gain ratio estimation is detailed in Figure 10 and will be explained below. The gain ratio 
estimation is interpolated every 64 samples, expressed in dB and subtracted from the measured gain ratio. The resulting 

gain differences or gain corrections, noted g^ to g„^_i in Figure 9, are quantized as 4-dimensional vectors, i.e. 4 

values per 256-sample frame. 

The gain estimation computed from filters A (z) and A hf (z) is detailed in Figure 12. These two filters are available at 
the decoder side. The first 64 samples of a decaying sinusoid at Nyquist frequency ;rradians per sample is first 
computed by filtering a unit impulse through a one-pole filter. The Nyquist frequency is used since the goal is to match 
the filter gains at around Fs/4 kHz, i.e. at the junction frequency between the LF and HF signals. Note the 64-sample 
length of this reference signal is the sub-frame length (64 samples). The decaying sinusoid is then filtered first through 

A (z), to obtain a low-frequency residual, then through 1/ A hf (z) to obtain a synthesis signal from the HF synthesis 

filter. We note that if filters A (z) and A hf (z) have identical gains at the normalized frequency of ;r radians per 

sample, the energy of the output of 1/ A hf (z) would be equivalent to the energy of the input of A (z) (the decaying 
sinusoid). If the gains differ, then this gain difference is taken into account in the energy of the signal at the output, 
noted x(n). The correction gain should actually increased as the energy ofx(n) decreases. Hence, the gain correction is 
computed as the multiplicative inverse of the energy of signal x(n), in the logarithmic domain (i.e. in dB). To get a true 
energy ratio, the energy of the decaying sinusoid, in dB, should be removed from the output. However, since this energy 
offset is a constant, it will simply be taken into account in the gain correction encoder. 

At the decoder, the gain of the HF signal can be recovered by adding g^ to g„^_i (known at the decoder) to the 
decoded gain corrections. 
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Figure 10: Gain matching between low and high frequency envelope 
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5.5 Stereo signal encoding 

5.5.1 Stereo Signal Low-Band Encoding 
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5.5.1.1 



Principle 



The stereo Low band encoder receives the signals X^^^ (n) and X^^^ (n) for encoding. The Low band encoder is 

based on fidehty optimized encoding of the low band side signal. The Lo side signal is obtained by computing the 
difference 

The encoding of the side signal is performed following a similar approach to that of the core encoder, except that the 
ACELP mode is not used. For each input signal block, the encoder decides in closed loop which encoding models to 
use. A signal to noise ratio fidelity criterion is used. 

All 4 encoding models are based on encoding in the frequency domain a redundancy reduced side signal. In order to 
account for transients, there is an encoding model that uses pre-echo reduction. Encoding in the frequency domain uses 
the same split multi-rate lattice VQ. 

Within each super- frame, the different encoding modes are: 



mode 


Duration (length + overlap) 


Encoding 





40 + 8 


RR + Pre-echo + AVEQ 


1 


40 + 8 


RR + AVEQ 


2 


80 + 16 


RR + AVEQ 


3 


160 + 32 


RR + AVEQ 



The timing chart as well as the possible mode combinations is similar to that of the core encoder and is described in the 
following figure: 

Si 
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Selection of the encoding mode is done by closed loop search identical to the one used for the core encoder. 
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5.5.1.2 



Signal Windowing 



The two signals X^^^ (n) and X^^^ (n) are windowed prior to redundancy removal and frequency transformation. This 

is necessary in order to apply overlap-add to minimize the framing effects due to quantization. The window shape is 
adaptive depending on the previous coding mode and is similar to that described in section 5.3.5.4. The windowed 

signals are denoted by x^^^ (n) and x^^^ (n) . 



5.5.1.3 



Pre-echo mode 



In order to encode transients more efficiently, a pre-echo mode is used. It is often the case in transients that the energy 
envelope of the mono signal is highly correlated with that of the side signal. The energy envelope of the mono signal is 
derived and normalized, it is then used to compensate for the energy envelope of the side signal. 

5.5.1 .4 Redundancy reduction 

For all encoding modes, a balance factor is used in order to remove the portion of the side signal that is correlated with 
the mono signal. The balance factor is given by 

balance _ factor = "" .^-^ 

n 

the balance factor is quantized by a uniform scalar quantizer with 7 bits. 

5.5.2 Stereo Signal Mid-Band Processing 



5.5.2.1 



Principle 



The encoder takes the mid band mono and right channel signals, X^^-^ (jl) and Xj^j^^^ (jl) , and inverse filters it with 

the core codec LPC filters derived from the mono signal. In the residual domain a shape constrained FIR filter is 
computed for approximating the side signal. The filter is computed by means of the covariance method using a novel 
spectral shape constraint. A new filter is computed for each Ldiv=256 sample frame with an analysis frame of 320 
samples. The energy of the filter is smoothed to avoid sudden energy changes. The smoothed filter is quantized with a 
multistage predictive vector quantizer (MSPVQ). 

The mono residual signal Cj^j^-^ (n) is filtered with the quantized filter and gain factors are computed for the left and 
right channels respectively. 
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5.5.2.2 Residual computation 

The residual signal is computed according to 

16 

euMid (^) = Z ^i ^^^^MMid (^ - 0, < ^ < L^.^ + L^^^f^ 

i=0 
16 



^RMid (^) = Z ^i (^"^^RMid (^ - 0, 0<n< L,.^ + L^^,f^ 



i=0 



The quantized and interpolated LPC coefficients from the core codec are used in the inverse filter operation, in addition 
an extra subframe is computed for the overlapped analysis section. The residual side signal is computed as 

^SMid (^) = ^MMid (^) - ^RMid (^)' ^ ^ < L,iv + L,,,f, 

5.5.2.3 Filter computation, smoothing and quantization 

8 
eSMid(^)-T.'^i^MMid(^-0 



n2 

under the constraint 



/=o 



The filter is computed that minimizes the expression /^ 

of a spectral null at OHz. The filter coefficients for the filter are computed with the well know co variance method using 
a modified cholesky algorithm taking into account the shape constraint. 

To avoid to fast changes in the filter energy, the filter energy is smoothed over time. The filter energy is first computed 
as 



E^-Jlb, 



2 
i=0 



the new filter energy is computed such that the filter energy is saturated to 16 and that transitions between frames are 
limited within a +/- 1.5 dB interval. 

After the smoothing operation the filter coefficients are quantized using a predictive multistage vector quantizer. 

5.5.2.4 Channel energy matching 

The quantized filter coefficients b^ ,b.,...,b^ are used to filter the mono signal excitation in order to get an initial 
estimate of the left and the right channel excitation signals. These estimates are computed as 

8 

^LMid (^) = ^MMid (^) - TjK^MMid (^ - 0, 0<n< L^.^ + L^^,f^ 

8 

^RMid (^) = ^MMid (^)+ Z K^MMid (^ - 0, < ^ < L^.^ + L^^,f^ 

i=0 

The energy matching for the left and right channels is computed as 

^div'^^subfr 

n=0 
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g^=101og, 






n=0 



=0 



The computed gains are adjusted in case of anti-correlation by computing a correlation gain 



4 Y.e^Midi^f 



8 CORK ~ ^^^^§10 L^. 



n=0 



Y.^RMiAnf+^RMiAnf 



«=0 



if gcoRR ^ ^^ the gain matching factors are adjusted according to 



\gL ^L<OdB 

I max(0, g^+gcoRR) otherwise 



and g^ 



\gR 



g«<OdB 
otherwise 



The energy matching factors are quantized using a two-dimensional vector-quantizer. 

5.5.3 Stereo Signal High-Band Processing 

In the stereo case two bandwith extensions are used. Both use the mono coder excitation as excitation source. 



5.6 



Packetization 



5.6.1 Packetization of TCX encoded parameters 

This section explains how the TCX encoded parameters are put in one or several binary packets for transmission. One 
packet is used for 256-sample TCX, while respectively 2 and 4 packets are used for 512- and 1024-sample TCX. To 
split the TCX spectral information in multiple packets (in case of 512- and 1024-sample TCX), the spectrum is divided 
into interleaved tracks, where each track contains a subset of the splits in the spectrum (each split represent 8- 
dimensional vectors encoded with algebraic VQ, and the bits of individual splits are not divided across different tracks). 
If we number the splits in the spectrum, from low to high frequency, with the split numbers 0, 1,2, 3, etc. up to the last 
split at the highest frequency, then the tracks are as shown in the following table 

Table 13: Dividing spectral splits in different tracks for packetization 







Split numbers 


256-sample- 
TCX 


Track 1 


0,1,2, 3, etc (only one track) 


512-sample 


Track 1 


0, 2, 4, 6, etc. 


TCX 


Track 2 


1,3,5, 7, etc. 


1024- 


Track 1 


0,4,8, 12, etc. 


sampleTCX 


Track 2 


1,5,9, 13, etc. 




Track 3 


2, 6, 10, 14, etc. 




Track 4 


3, 7, 11, 15, etc. 



Then, recall that the parameters of each split in algebraic VQ consist of the codebook numbers n=[no ... Hk-i] and the 
indices i=[io ... Ik-i] of all splits. The values of codebooks numbers n are in the set of integers {0, 2, 3, 4,. . . }. The size 
(number of bits) of each index 4 is given by 4nk. To write these bits into the different packets, we associate a track 
number to each packet. In the case of 256-sample TCX, only one track is used (i.e. all the splits in the spectrum) and it 
is written in a single packet. In the case of 512-sample TCX, two packets are used: the first packet is used for Track 1 
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and the second packet for Track 2. In the case of 1024-sample TCX, four packets are used: the first packet is used for 
Track 1, the second packet for Track 2, the third packet for Track 3 and the fourth packet for Track 4. However, the 
spectrum quantization and bit allocation was performed without constraining each track to have the same amount of 
bits, so in general the different tracks do not have the same number of bits allocated to the respective splits. Hence, 
when writing the encoded splits (codebook numbers and lattice point indices) of a track into their respective packet, two 
situations can occur: 1) there are not enough bits in the track to fill the packet or 2) there are more bits in a track than 
the size of the packet so there is overflow. The third possibility (exactly the same number of bits in a track as the packet 
size) occurs rarely. This overflow has to be managed properly, so all packets are completely filled, and so the decoder 
can properly interpret and decode the received bits. This overflow management will be explained below when the 
multiplexing for the case of multiple binary tables (i.e. tracks) is detailed. 

The split indices are written in their respective packets starting from the lowest frequency split and scanning the track in 
the spectrum in increasing value of frequency. The codebook number Hk and index /^ of each split are written in 
separate sections of the packet. Specifically, the bits of the codebook number Hk (actually, its unary code 
representation) are written sequentially starting from one end of the packet, and the bits of the index /^ are written 
sequentially starting from the other end of the packet. Hence, overflow occurs when these concurrent bit writing 
processes attempt to overwrite each other. Alternatively, when the bits in one track do not completely fill a packet, there 
will be a "hole" (i.e. available position for writing more bits) somewhere in the middle of the packet. In 512-sample 
TCX, overflow will only occur in one of the two packets, while the other packet will have this "hole" where the 
overflowing bits of the other packet will be written. In 1024-sample TCX, there can be "holes" in more than one of the 
four packets after overflow has happened. In this case, all the "holes" will be grouped together and the overflowing bits 
of the other packets will be written into these "holes". Details of this procedure are given below. 

Then, we note that the use of a unary code to encode the lattice codebook numbers (n) implies that each split requires 
actually Sn^ bits, when it is quantized using a point in the lattice codebook with number Uk. That is, n^ bits are used by 
the unary code (% -1 successive "I's" and a final "0") to indicate how many blocks of 4 bits are used in the codebook 
index, and Arik bits are used to form the actual lattice codebook index in codebook nj^ for the split. Note also that when a 
split is not quantized (i.e. set to zero by the TCX quantizer), it still requires 1 bit (a "0") in the unary code, to indicate 
that the decoder must skip this split and set it to zero. 

Now, more details related to the multiplexing of algebraic vector quantizer indices in one or several packets are given 
below, in particular regarding the splitting of TCX indices in more than one packet (for 512-and 1024-sample TCX) and 
the management of overflow in writing the bits into the packets. 

Recall that the codebook numbers are integers defined in the set {0,2,3,4,...., 36}. Each % has to be represented in a 
proper binary format, denoted hereafter n^k, for multiplexing. 

5.6.1 .1 Multiplexing principle for a single binary table 

The multiplexing in a single binary table t consists of writing bit-by-bit all the elements of n and i inside t, where the 
table t = (^,. . ., ^R.i) contains R bits (which corresponds to the number of bits allocated to algebraic VQ). 

A straightforward strategy amounts to writing sequentially the elements of n^ and i in the binary table t, as follows: 

\n^o io n^i ii n^i h -- ] 

In this case, the bits of n^o are written from position in t and upward, the bits of /q then follow, etc. This format is 
uniquely decodable, because the encoded codebook number n^j, indicates the size of 4. 

Instead, an alternative format is used as described below: 

[ioiii2 n^2 n^ n^o ] 

The codebook numbers are written sequentially and downward from the end of the binary table t, whereas the indices 
are written sequentially and upward from the beginning of the table. This format has the advantage to separate 
codebook numbers and indices. This allows to take into account the different bit sensitivity of codebook numbers and 
indices. Indeed, with the multi-rate lattice vector quantization used, the codebooks numbers are the most sensitive 
parameter sThus, they are written from the beginning of the table t and take around 20% of the total bit consumption, 
giving bitstream ordering according to bit sensitivity. 

For the actual multiplexing, two pointers are then defined on the binary table t: one for (encoded) codebooks numbers 
poSn, another for indices poSi. The pointer poSi is initialized to (i.e. the beginning of the binary table), SindpoSn to R-1 
(i.e. the end of the binary table). Positive increments are used for poSi, and negative ones for poSn. At any time, the 
number of bits left in the binary table is given by poSn-poSi-\-l. 
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The table t is initialized to zero. This guarantees that if no data is written, the data inside this table will correspond to an 
all-zero codebook numbers n (this follows from the definition of the unary code used here). The splits are then written 
sequentially in the binary table from k=0 to K-1: [n^o k] then [n^j ij] then [n^2 h]^ etc. 

The data of the ^th split are really written in the binary table t only if the minimal bit consumption of the ^h split, 
denoted Rj, hereafter, is less than the number of bits left in table t, i.e. if Rj, < poSn-poSi-\-l. For the multi-rate lattice 
vector quantization used here, the minimal bit consumption Rj, equals to bit if ^^^=0, or Srik-l bits ifnk>2. 

The multiplexing works as follows as shown in the algorithm of Figure 1 1 . 



Initialization; 

poSi=0, poSn=R-1 

set binary table t to zero 

For /c=0 to K-1 (loop for all splits over the 4 steps below): 

Compute the number of left bits in table t: /7ib=pos^-pos,+1 

Compute the minimal bit consumption of the Mh split: Rk =0 if n,^0, 5/7/,-1 
if /7/^2 



Figure 1 1 : Multiplexing algorithm for one binary table 

In practice, the binary table t is physically represented as having 4-bit elements instead of binary (1-bit) elements, so as 
to accelerate the write-in-table operations and avoid too many bit manipulations. This optimization is significant 
because the indices 4 are typically formatted into 4-bit blocks. In this case, the value of poSi is always a multiple of 4. 
However, this implies to use bit shifts and modular arithmetic on pointers poSn and poSi to locate positions in the table. 



5.6.1.2 



Multiplexing in case of multiple binary tables 



In the case of multiple binary tables, the algebraic VQ parameters are written in P tables to, ..., t^.; (P>1) containing 
respectively r^, ..., rp.j bits, such that ro-\- . . .-\-rp.j = R. In other words, the bit budget allocated to algebraic VQ 
parameters, R, is distributed to P binary tables. Here, L is set to 1 in the 256-sample TCX mode, 2 in the 512-sample 
TCX mode or 4 in the 1024-sample TCX mode. 

Note that the multiplexing of algebraic VQ parameters in TCX modes employs frame-zero-fill if the bit budget 
allocated to algebraic VQ is not fully used. 

We assume that the number of sub- vectors, K, is a multiple of P. Under this assumption, the algebraic VQ parameters 
are then divided into P groups of equal cardinality: each group comprises K/P (encoded) codebook numbers and K/P 
indices. By convention, the pth group is defined as the set (n^p+jp, ip+jp)j=o..K/p-i- This can be seen as a decimation 
operation (in the usual multi-rate signal processing sense). 

Assuming the size of table t^ is sufficient, the parameters of the pth group are written in table tp. For the sake of clarity, 
the division of sub- vectors is explained below in more details for P=l and 2: 

If P=l, the set (n^p+jp, ip+jp)j=o..K/p-i for /=0 simply corresponds to (n^o, k, •••, ^^k-u ix-i)- These parameters are written in 
table to. This is the single-table case. 

If P=2, we have (n^p+jp, ip+jp)j=o..K/p-i = (n^o, k, n^i, h---, n^K-i, Ik-i) fovp=Q and (^^, i^ n^s, is..., n^K-h k-i) for p=\. 
Assuming the table sizes are sufficient, the parameters {n^o^ k, n^2, h---, ^\-2, Ik-i) are written in table to, while the other 
parameters (n^j, i^ n^s, is..., n^K-h Ik-i) are written in table t;. 

The case of P=4 can be readily understood from the case of P=2. 

As a consequence, in principle the multiplexing in the multiple-table case boils down to applying several times the 
single-table multiplexing principle: the (encoded) codebook numbers (n^p+jp)j=o..K/p-i can be written upward from the 
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bottom of each table t^ and the indices (ip+jp)j=o..K/p-i can be written downward from the end of each table tp. Two 
pointers are defined for each binary table t^: poSn,p SindpoSip. These pointers are initialized to poSip= SindpoSn,p= r^-l, 
and are respectively incremented and decremented. 

Nonetheless, the multiple-table case is not a straightforward extension of the single-packet case. It may happen indeed 
that the number of bits in (n^p+jp, ip+jp)j=o..K/p-i exceeds, for a given /?, the number of bits, r^, available in the binary table 
tp. To deal with such an "overflow", an extra table texis defined as temporary buffer to write the bits in excess (which 
have to be distributed in another table tg with q^p). The size of tex is set to 4*36 bits. 

The actual multiplexing algorithm in the multiple-table case is detailed below: 

1) Initialize: (We assume that a size of r^ bits for each binary table t^.) 

Set total number of bits to R\ nb = R 

Initialize the maximum position last such that riiast ^ 2: 

last = -l 

Forp=O...P-l, 

poSi p = and poSn,p = rp -li 

set table tp to zero 

2) Split and write all codebook numbers: 

For p=O...P-l, the (encoded) codebook numbers (n^p+jp)j=o..K/p-i are written sequentially (downward from the end) in 
table tp. This is done through two nested loops over p and j. In the illustrative embodiment a single loop is used with 
modular arithmetic, as detailed below: 

Fory^=0,...,^-1 

p =k mod P 

Compute the minimal bit consumption of the ^h split: Rk = if nk=0, Sn^-l ifnk>2 

If Rk > nb, nk=0 else nb = nb - R^ 

If %> 2, last = k 

Write downward n^j, (except the stop bit) in table tp starting from poSn,p, and decrement /76>5'^,^ by nk-l 

If nb > 0, write the stop bit of the unary code and decrement poSn,p by 1 

It can be checked that for P<4 with a near-equal distribution of 7? in r^, no overflow (i.e. bit in excess) in tables t/ 
can happen at this step (for p=0,..,P-l). In general this property must be verified to apply the algorithm. 



3) Split and write all indices: 

This is the tricky part of the multiplexing algorithm due to the possibility of overflow. 

Find the positions pos^^^p in each binary table tp (with p= I...P) from which the bits in overflow can be written. 
These positions are computed assuming the indices are written by 4-bit block. 

¥orp = {)..P-\ 

pos = 

nb = poSn,p + 1 

For k = pto last with a step of P 

lf%>0. 
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If 4nk <nb, nbj = n^ 

else nbi = nb»2 (where » is a bit shift operator) 

nb = nb - 4* nbj 

pos = pos + nbi 

pos°^^p=pos*4 

The indices can then be written as follows: 

For/7 = 0..P-l 

pos = 

For l = p to N-l with a step of P 

nb = poSn,p - pos 

Write the 4nk bits ofi^: 

Compute the number, nbi, of 4-bit blocks which can fit in table t^ and the number, nb2, of 4-bit blocks in excess (to be 
written temporarily in table iex)'- 

If 4nk < nb, nbi = n^, nb2 = 

else nbi = nb » 2 (where » is a bit shift operator), nb2 = n^ - nbi 
Write upward the 4nbi bits of 4 from. postp to poSip+Anbi-\ in table t^, and mcxtmQni postp by 4nbi 

If^Z?2>0, 

Initialize poSovf to 

Write upward the remaining 4nb2 bits of 4 fvo\x\poSovfto poSovj+^nb2-l in table iex, and mcxtmQni pos ovf^y 4nbovf 

Distribute the 4nb2 bits in table tp (with q^p) based on the pointers pos^^-^g and poSn,q and the pointers pos^^-^g are 
updated. 

5.6.2 Packetization procedure for all parameters 

The coding parameters computed in a 1024-sample super- frame at the encoder are multiplexed into 4 binary packets of 
equal size. The packetization consists of a multiplexing loop over 4 iterations. The size of each packet is set to Rmai^ 4 
where Rfotai is the number of bits allocated to the super- frame. 

Recall that the mode selected in the 1024-sample super- frame has the form (mi, m2, nis, m4), where mk=0, 1, 2 or 3, with 
the mapping: -^ 256-sample ACELP, 1 -^ 256-sample TCX, 2 -^ 512-sample TCX, 3 -^ 1024-sample TCX 
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Figure 12: Structure of transmission packets for all four frame types 

The multiplexing in the k-ih packet is performed according to the value of ruk. The corresponding packet format is 
shown in Figure 12. There are 3 cases: 

\fmk=^ or 1, the ^-th packet simply contains all parameters related to a 256-sample frame, where the parameters are the 
2-bit mode information ('00' or '01' in binary format), the parameters of ACELP or those of 256-sample TCX, and the 
parameters of 256-sample HF coding. 

If mk=-2, the p-\h packet contains half of the bits of the 512-sample TCX mode, half of the bits of 512-sample HF 
coding, plus the 2-bit mode information ('10' in binary format). 

If mk=?>, the ^-th packet contains one fourth of the bits describing the 512-sample TCX mode, one fourth of the bits of 
1024-sample HF coding, plus the 2-bit mode information ('1 1' in binary format). 

The packetization is therefore straightforward if the k-i\\ packet corresponds to ACELP or 256-sample TCX. The 
packetization is slightly more involved if 512- or 1024-sample TCX mode is used, because the bits of the 512- or 1024- 
sample modes have to be shared into even parts. 
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5.6.3 TCX gain multiplexing 



It was found that the TCX gain is important to maintain audible quahty in case of packet loss. Thus, in 512-sample and 
1024-sample TCX frames, the TCX gain value is encoded redundantly in multiple packets to protect against packet loss. 
The TCX gain is encoded at a resolution of 7 bits, and these bits are labelled "Bit 0" to "Bit 6", where "Bit 0" is the 
Least Significant Bit (LSB) and "Bit 6" is the Most Significant Bit (MSB). We consider two cases, TCX512 and 
TCX 1024, where the encoded bits are split into two or four packets, respectively. 

At the Encoder side 

TCX512: The first packet contains the full gain information (7 bits). The second packet repeats the most significant 6 
bits ("Bit 1" to "Bit 7"). 

TCX1024: The first packet contains the full gain information (7 bits). The third packet contains a copy of the three 
bits "Bit 4", "Bit 5" and "Bit 6". The fourth packet contains a copy of the three bits "Bit 1", "Bit 2" and "Bit 3". 

Additionally, a 3-bit "parity" is formed as thus: combining by logical XOR "Bit 1" and "Bit 4" to generate "Parity Bit 
0", combining by logical XOR "Bit 2" and "Bit 5" to generate "Parity Bit 1", and combining by logical XOR "Bit 3" and 
"Bit 6" to generate "Parity Bit 2". These three parity bits are sent in the second packet. 

At the Decoder side 

The logic applied at the decoder to recover the TCX gain when missing packets occur for 512-sample TCX and 1024- 
sample TCX. We assume that there is at least one packet missing before entering the flowchart. 

TCX512: If the fist packet is flagged as being lost, the TCX global gain is taken from the second packet, with the LSB 
("Bit 0") being set to zero. If only the second packet is lost, then the full TCX gain is obtained from the first packet. 

TCX1024: The gain recovery algorithm is only used if 1 or 2 packets forming an 1024-sample TCX frame are lost; 
as described in Section 6.5.1.1. If 3 or more packets are lost in a TCX 1024 frame, the MODE is changed to (1,1,1,1) 
and BFI=(1,1,1,1). When only 1 or 2 packets are lost in a TCX 1024 frame, the recovery algorithm is as follows: 

As described above, the second, third and fourth packets of a TCX 1024 frame contain the parity bits, "Bit 6" to "Bit 4", 
and "Bit 3" to "Bit 1" of the TCX gain. These bits (three each) are stored in "parity", "indexO" and "indexl" 
respectively. 

If the third packet is lost, "indexO" is replaced by the logical XOR combination of "parity" and "indexl". That is, "Bit 6" 
is generated from the logical XOR of "Parity Bit 2" and "Bit 3", "Bit 5" is generated from the logical XOR of "Parity 
Bit 1" and "Bit 2", and "Bit 4" is generated from the logical XOR of "Parity Bit 0" and "Bit 1". 

If the fourth packet is lost, "indexl" is replaced by the logical XOR combination of "parity" and "indexO. That is, "Bit 
3" is generated from the logical XOR of "Parity Bit 2" and "Bit 6", "Bit 2" is generated from the logical XOR of "Parity 
Bit 1" and "Bit 5", and "Bit 1" is generated from the logical XOR of "Parity Bit 0" and "Bit 4". 

Finally, the 7-bit TCX gain value is taken from the recovered bits ("Bit 1" to "Bit 6") and "Bit 0" is set to zero. 
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5.6.4 Stereo Packetization 
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Stereo parameters computed in a 1024-sample super- frame at the encoder are multiplexed into 4 binary packets of equal 
size. The packetization consists of a similar multiplexing loop as for the core encoder. The stereo packets are appended 
at the end of the mono packets. 



Functional description of the decoder 



The function of the decoder consists of decoding the transmitted parameters (LP parameters, ACELP/TCX mode, 
adaptive codebook vector, adaptive codebook gain, fixed codebook vector, fixed codebook gain, TCX parameters, high- 
band parameters, stereo information) and performing synthesis to obtain the reconstructed low-frequency and high- 
frequency signals. For stereo signal synthesis, the stereo low- and mid-band signals are reconstructed using the low- 
frequency mono signal and the transmitted and decoded stereo parameters (...). 

Section 6.1 describes the reconstruction, by the decoder, of the mono low-band signal in the O-Fs/4 kHz bandwidth 
(core ACELP/TCX decoder). The reconstruction of the higher frequency band using bandwidth extension and the 
mixing of the low and high frequencies of the mono signal will be described respectively in Sections 6.2 and 6.3. The 
generation of the stereo signals will be described in Section 6.4. Finally, Section 6.5 describes the concealment 
algorithm in the case of missing frames. 

6.1 Mono Signal Low-Band synthesis 

The O-Fs/4 kHz band of the mono signal is reconstructed by the core ACELP/TCX decoder. In ACELP mode, the 
decoder is the same as AMR-WB. The TCX mode of the decoder will be described in more details below. Selection 
between ACELP and TCX decoding in each 256-sample frame is controlled by the mode indicators described in Section 
5.2.2 of the encoder. These mode indicators are transmitted as 2 bits in each 256-sample packet. 
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6.1 .1 ACELP mode decoding and signal synthesis 



Same as 3GPPTS 26.190. 



6.1 .2 TCX mode decoding and signal synthesis 



The TCX decoder is shown in Figure 13. 
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b) TCX decoding in normal operation or in case of partial packet loss. 

Figure 13: Block diagram of the TCX decoder 

Figure 13 shows a block diagram of the TCX decoder including the following two cases: 

Case 1: Packet-erasure concealment in TCX-256 when the TCX frame length is 256 samples and the related packet is 
lost i.e. BFI_TCX = (1), as shown in Figure 13-a. 

Case 2: Normal TCX decoding, possibly with partial packet losses, as shown in Figure 13-b.. 

In Case 1, no information is available to decode the 256-sample TCX frame. The TCX synthesis is found by processing 
the past excitation delayed by T, where T=pitch_tcx is a pitch lag estimated in the previously decoded TCX frame, by a 

non-linear filter roughly equivalent to l/A(z).A non-linear filter is used instead of 1/ A(z) to avoid clicks in the 
synthesis. This filter is decomposed in 3 steps: 

Step 1: filtering by 
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kzly) 1 
A{z) \-ccz~' 

to map the excitation delayed by T into the TCX target domain; 
Step 2: applying a limiter (the magnitude is limited to ± rms^syn) 
Step 3: filtering by 

kzly) 

to find the synthesis. Note that the buffer OVLP_TCX is set to zero in this case. 
Decoding of the algebraic VQ parameters 

In Case 2, TCX decoding involves decoding the algebraic VQ parameters describing each quantized block B\ of the 

scaled spectrum X\ where X' is as described in Step 2 of Section 5.3.5.7. Recall that X' has dimension A^, where N = 
288, 576 and 1152 for TCX-256, 512 and 1024 respectively, and that each block B'j, has dimension 8. The number K of 
blocks B'k is thus 36, 72 and 144 for TCX-256, 512 and 1024 respectively. The algebraic VQ parameters for each block 
B'k are described in Step 5 of Section 5.3.5.7. For each block 5'^^ , three sets of binary indices are sent by the encoder: 

a) the codebook index rik, transmitted in unary code as described in Step 5 of Section 5.3.5.7; 

b) the rank 4 of a selected lattice point c in a so-called base codebook, which indicates what permutation has to be 
applied to a specific leader (see Step 5 of Section 5.3.5.7) to obtain a lattice point c; 

c) and, if the quantized block B'^ (a lattice point) was not in the base codebook, the 8 indices of the Voronoi 

extension index vector k calculated in sub-step VI of Step 5 in Section; from the Voronoi extension indices, an 
extension vector z can be computed as in reference [7]. The number of bits in each component of index vector k 
is given by the extension order r, which can be obtained from the unary code value of index rik . The scaling 
factor M of the Voronoi extension is given by M = 2\ 

Then, from the scaling factor M, the Voronoi extension vector z (a lattice point in REs) and the lattice point c in the base 
codebook (also a lattice point in REs), each quantized scaled block B\ can be computed as 

B\ = Mc + z 

When there is no Voronoi extension (i.e. nk<5, M=l and z=0), the base codebook is either codebook Qq, Q2, Q3 or Q4 
from reference [6]. No bits are then required to transmit vector k. Otherwise, when Voronoi extension is used because 

B\ is large enough, then only Q^ or Q4 from reference [6] is used as a base codebook. The selection of Q3 or Q4 is 

implicit in the codebook index value %„ as described in Step 5 of Section 5.3.5.7. 

Decoding of the noise-fill parameter 

The noise fill-in level (Jnoise is decoded by inverting the 3 -bit uniform scalar quantization calculated at the encoder as in 
Step 4 of Section 5.3.5.7 . For an index < idxi < 7, cJnoise is given by: (Jnoise = 0.1 * (8 - idxi). However, it may happen 
that the index idxi is not available. This is the case when BFI_TCX = (1) in TCX-256, (1 X) in TCX-512 and (XI XX) 
in TCX- 1024, with X representing an arbitrary binary value. In this case, cJnoise is set to its maximal value, i.e. (Jnoise = 
0.8. 

Comfort noise is injected in the sub vectors B^ rounded to zero and which correspond to a frequency above Fs/2 kHz 4. 
More precisely, Z is initialized as Z = F and for K/6 < k < K (only), if F^ = (0, 0, ...,0), Z^ is replaced by the 8- 
dimensional vector: 

<^noise * [ cos(0i) sin(0i) cos(02) sin(02) cos(03) sin(03) cos(04) sin(04) ], 

where the phases 0i, 02, 03 and 04 are randomly selected. 
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Low-frequency de-emphasis 

After decoding the algebraic VQ parameters and noise-fill parameter, we obtain the quantized pre-shaped TCX 
spectrum X'. De-shaping is then applied as in Section 5.3.5.6. 

Estimation of the dominant pitch value 

The estimation of the dominant pitch is performed so that the next frame to be decoded can be properly extrapolated if it 
corresponds to TCX-256 and if the related packet is lost. This estimation is based on the assumption that the peak of 
maximal magnitude in spectrum of the TCX target corresponds to the dominant pitch. The search for the maximum M is 
restricted to a frequency below Fs/64 kHz 

M = maXi.i..N/32 (X'2i)'+(X'2i.i)' 

and the minimal index 1 < /^ax ^ A//32 such that ( X\i )^+ ( X\i+i )^ = M is also found. Then the dominant pitch is 
estimated in number of samples as Test = A^ / /max (this value may not be integer). Recall that the dominant pitch is 
calculated for packet-erasure concealment in TCX-256. To avoid buffering problems (the excitation buffer being 
limited to 256 samples ), if Jest > 256 samples, pitchjtcx is set to 256 ; otherwise, if Test ^ 256, multiple pitch period in 
256 samples are avoided by ^Qiimg pitchjtcx to 

pitchjtcx = max { L n Test J I n integer > and n Test < 256} 

where L. J denotes the rounding to the nearest integer towards -oo. 

Inverse transform 

To obtain the quantized perceptual signal, an inverse transform is applied to the de-shaped spectrum X'. The transform 
used at the encoder and decoder is a the discrete Fourier transform, and is implemented as an FFT and IFFT, 
respectively. Recall that due to the ordering used at the TCX encoder, the transform coefficients X'=(X'o,...,X'n.j) are 
such that: 

X'o corresponds to the DC coefficient, 

X'j corresponds to the Nyquist frequency, and 

the coefficients X'2k and X'2k+h for ^=1.. N/2-1, are the real and imaginary parts of the Fourier component of 
frequency of k(/N/2) * Fs/4 kHz. 

X'j is always forced to 0. After this zeroing, the time-domain TCX target signal jc'^ is found by applying an inverse FFT 
to the quantized scaled spectrum X. Rescaling will be applied in the following section, to obtain the total quantized 
weighted signal prior to windowing and overlapping. 

Decoding of the glocal TCX gain and scahng 

The (global) TCX gain ^tcx is decoded by inverting the 7 -bit logarithmic quantization calculated in the TCX encoder as 
in Section 5.2.5.10 . First, the r.m.s. value of the TCX target signal x'^ is computed as: 

rms = sqrt(l/A^ (x'^o^ + -^'wi^ +• • •+ -^wl-;^)) 

From the received 7-bit index < idxj < 127, the TCX gain is given by: 

— 10 '"'^•^2 / 28/(4 X rms) 

The (logarithmic) quantization step is around 0.71 dB. 

This gain is used to scale x'^ into x^. Note that from the mode extrapolation and the gain repetition strategy, the index 
idx2 is available in case of frame loss. However, in case of partial packet losses (1 loss for TCX-512 and up to 2 losses 
for TCX- 1024) the least significant bit of idx2 may be set by default to in the demultiplexer. 

Windowing and overlap 

Since the TCX encoder employs windowing with overlap and weighted ZIR removal prior to transform coding of the 
target signal, the reconstructed TCX target signal x = (xq, Xi, . . ., x^.i) is actually found by overlap-add. The overlap-add 
depends on the type of the previous decoded frame (ACELP or TCX). The TCX target signal is first multiplied by a 
window w = [wq Wi . . . Wa^.;], whose shape is described in Section 5.3.5.4. 
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Then, the overlap from the past decoded frame (OVLP_TCX) is added to the present windowed signal x. The overlap 
length OVLP_TCX depends on the past TCX framelength and on the mode of the past frame (ACELP or TCX). 

Computation of the synthesis signal 

The reconstructed TCX target is then filtered through the zero-state inverse perceptual filter 
W (z) = (1 - (XZ )/ A(z I Y) to find the synthesis signal which will be applied to the synthesis filter. The excitation 

is also calculated to update the ACELP adaptive codebook and allow to switch from TCX to ACELP in a subsequent 
frame. Note that the length of the TCX synthesis is given by the TCX frame length (without the overlap): 256, 512 or 
1024 samples. 

6.1 .3 Post-processing of Mono Low-Band signal 

In the low-frequency pitch enhancement, two-band decomposition is used and adaptive filtering is applied only to the 
lower band. This results in a total post-processing that is mostly targeted at frequencies near the first harmonics of the 
synthesized speech signal. 
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Figure 14: Block diagram of the low frequency pitch enhancer 

Figure 14 shows the block diagram of the two-band pitch enhancer. In the higher branch the decoded signal is filtered 
by a high-pass filter to produce the higher band signal (^h)- In the lower branch, the decoded signal is first processed 
through an adaptive pitch enhancer, and then filtered through a low-pass filter to obtain the lower band post-processed 
signal (^lef)- The post-processed decoded signal is obtained by adding the lower band post-processed signal and the 
higher band signal. The object of the pitch enhancer is to reduce the inter-harmonic noise in the decoded signal, which 
is achieved here by a time- varying linear filter with a transfer function 

H,(z) = {l-a) + ^z'+^z-' 

and described by the following equation: 



CX (X 

s^^in) = (1 - a)s{n) + —s(n- T) + —s{n + T) 



(1) 



where 6ir is a coefficient that controls the inter-harmonic attenuation, T is the pitch period of the input signal s{n) , 
and S^^^ (n) is the output signal of the pitch enhancer. Parameters T and a vary with time and are given by the pitch 
tracking module. With a value of 6ir= 1, the gain of the filter described by Equation (1) is exactly at frequencies 



ETSI 



3GPP TS 26.290 version 9.0.0 Release 9 



58 



ETSI TS 126 290 V9.0.0 (2010-01) 



l/(2T),3/(2T), 5/(27), etc.; i.e. at the mid-point between the harmonic frequencies 1/T, 3/T, 5/T, etc. When 6ir approaches 
0, the attenuation between the harmonics produced by the filter of Equation (1) decreases. 

To confine the post-processing to the low frequency region, the enhanced signal Sle is low pass filtered to produce the 
signal Slef which is added to the high-pass filtered signal Sh to obtain the post-processed synthesis signal Se. 

Another configuration equivalent to the one in Figure 14 is used here which eliminates the need to high-pass filtering. 
This is explained as follows. 

Let hipin) be the impulse response of the low-pass filter and hnpin) is the impulse response of the complementary high- 
pass filter. The post-processed signal SEin) is given by 



s^ (n) = s(n) * h^p (n) + s^^^ (n) * h^p (n) 
= s(n) * hfjp (n) + 



(1 - a)s(n) + -s(n-T) + - s(n + T) 



^Kp(n) 



= s(n) * hfjp (n) + s(n) * h^p (n) - 



0&{n) s{n-T) s{n + T) 

2 2 



{ 



sin) - 
sin) - 



a 



1 



1 



sin) sin -T) sin + T) 

2 2 



* h,p in) 



* h,p in) 



aei^j(n)*hi^pin) 



Thus, the post-processing is equivalent to subtracting the scaled low-pass filtered long-term error signal from the 
synthesis signal sin) . The transfer function of the long-term prediction filter is given by 

P^^(z) = l-0.5z^-0.5z-^ 

The alternative post-processing configuration is depicted in Figure 15. 
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Figure 15: Implemented post-processing configuration 



The value T is given by the received closed-loop pitch lag in each subframe (the fractional pitch lag rounded to the 
nearest integer). A simple tracking for checking pitch doubling is performed. If the normalized pitch correlation at delay 
T/2 is larger than 0.95 then the value T/2 is used as the new pitch lag for post-processing. 

The factor (I is by 
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a - 0.5g^ , constrained to < d? < 0.5 

where g is the decoded pitch gain. Note that in TCX mode the value of Ct is set to zero. 

A Hnear phase FIR low-pass filter with 25 coefficients is used, with a cut-off frequency at 5Fs/256 kHz (the filter delay 
is 12 samples). 

6.2 Mono Signal High-Band synthesis 

The synthesis of the HF signal implements a kind of bandwidth extension (BWE) mechanism and uses some data from 
the LF decoder. It is an evolution of the BWE mechanism used in the AMR-WB speech decoder. The HF decoder is 
detailed in Figure 16. The HF signal is synthesized in 2 steps: calculation of the HF excitation signal and computation 
of the HF signal from the HF excitation. The HF excitation is obtained by shaping in time-domain the LF excitation 
signal with scalar factors (or gains) per 64-sample subframes. This HF excitation is post-processed to reduce the 
"buzziness" of the output, and then filtered by a HF linear-predictive synthesis filter 1/Ahf(z). Recall that the LP order 
used to encode and then decode the HF signal is 8. The result is also post-processed to smooth energy variations. 
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Figure 16: Block diagram of high frequency decoder 

The HF decoder synthesizes an 1024-sample HF superframe. This superframe is segmented according to MODE = (mo, 
mi, m2, ms). To be more specific, the decoded frames used in the HF decoder are synchronous with the frames used in 
the LF decoder. Hence, m^< \, m^- 2 and m^- Z indicate respectively a 256, 512 and 1024-sample frame. These 
frames are referred to as HF-256, HF-512 and HF-1024, respectively. 

From the synthesis chain described above, it is clear that the only parameters needed for HF decoding are ISF and gain 
parameters. The ISF parameters represent the filter 1/Ahf(^), while the gain parameters are used to shape the LF 
excitation signal. These parameters are demultiplexed based on MODE and knowing the format of the bitstream. 

Control data which are internal to the HF decoder are generated from the bad frame indicator vector BFI = ihfi^, hfi\, 
bfi2, bfi^). These data are bfi_isf_hf, BFI_GAIN, and the number of subframes for ISF interpolation. The nature of 
these data is defined in more details below: 
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bfi_isf_hf is a binary flag indicating loss of the ISF parameters. Its definition is given below from BFI. 

For HF-256 in packet k bfi_isf_hf= bfiy^ , 

For HF-512 in packets k and k+1, bfi_isf_hf= bfi^ , 

For HF-1024 (in packets k=0 to 3), bfi_isf_hf= bfio 

This definition can be readily understood from the bitstream format. Recall that the ISF parameters for the HF signal are 
always in the first packet describing HF-256, -512 or -1024 frames. 

BFI_GAIN is a binary vector used to signal packet losses to the HF gain decoder: BFI_GAIN = ( bfii, ) for HF-256 in 
packet k, ( bfk ^//k+i ) for HF-512 in packets k and k-\-l, BFI_GAIN = BFI for HF-1024. 

The number of subframes for ISF interpolation refers to the number of 64-sample subframes in the decoded frame. This 
number is 4 for HF-256, 8 for HF-512 and 16 for HF-1024. 

The ISF vector isf_hf_q is decoded using AR(1) predictive VQ. If bfi_isf_hf= 0, the 2-bit index /i of the 1^^ stage and 
the 7 -bit index 12 of the 2"^ stage are available and isf_hf_q is given by 

isf_hf_q = cbl(/i) + cb2(/2) + mean_isf_hf + |iisf_hf * mem_isf_hf 

where cbl(/i) is the /i-th code vector of the 1^^ stage, cb2(/2) is the /2-th code vector of the 2^^ stage, mean_isf_hf is the 
mean ISF vector, |lisf_hf = 0-5 is the AR(1) prediction coefficient and mem_isf_hf is the memory of the ISF predictive 
decoder. 

If bfi_isf_hf= 1, the decoded ISF vector corresponds to the previous ISF vector shifted towards the mean ISF vector: 

isf_hf_q = a isf hf * mem_isf_hf + mean_isf_hf 

with a isf hf =0.9. After calculating isf_hf_q, the ISF reordering defined in AMR-WB speech coding is applied to 
isf_hf_q with an ISF gap of 9 Fs/1280 Hz. Finally the memory mem_isf_hf is updated for the next HF frame as: 

mem_isf_hf = isf_hf_q - mean_isf_hf 

Note that the initial value of mem_isf_hf (at the reset of the decoder) is zero. 

A simple linear interpolation between the ISP parameters of the previous decoded HF frame (HF-256, HF-512 or HF- 
1024) and the new decoded ISP parameters is performed. The interpolation is conducted in the ISP domain and results 
in ISP parameters for each 64-sample subframe, according to the formula: 

isPsubframe-.- = i^^b * ispnew + (l-l/nb) * isPoM, 

where nb is the number of subframes in the current decoded frame (nb=4 for HF-256, 8 for HF-512, 16 for HF-1024), 
i=0,...,nb-l is the subframe index, ispoM is the set of ISP parameters obtained from the ISF parameters of the previously 
decoded HF frame and ispnew is the set of ISP decoded. The interpolated ISP parameters are then converted into linear- 
predictive coefficients for each subframe. 

The computation of the gain gmatch in dB is detailed in the next paragraphs. This gain is interpolated for each 64-sample 
subframe based on its previous value 6>/J_gmatch as: 

g. = ilnb * gmatch + {l-ilnb) * old_g^^^ch, 

where nb is the number of subframes in the current decoded frame (nb=4 for HF-256, 8 for HF-512, 16 for HF-1024), 
i=0,...,nb-l is the subframe index. This results in a vector ( g^ , ... g„^_i ). 

Gain estimation computation to match magnitude at Fs/4 kHz 

Same as section 5.6 (Figure 9) 

Decoding of correction gains and gain computation 

Recall that after gain interpolation the HF decoder gets the estimated gains (g^%, g^^\, ..., g^^Vb-i) in dB for each of the 
nb subframes of the current decoded frame. Furthermore, nb = 4, S and 16 in HF-256, -512 and -1024, respectively. 
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The correction gains in dB are then decoded which will be added to the estimated gains per subframe to form the 
decode gains g^J^,..., |„^_i : 

(go(dB)J, (dB),..., g^,_,(dB)) = (g^,g,,..., g,,_i) + (go'S'i"-" 8nb-i) 
where 

/ 77 77 77 \ / cl cl cl \ , / c2 c2 c2 \ 

(80^81^ '-'^ 8nb-0 = ^S U8 U'--^8 nb-l) + (^ 0,^ 1,..-,^ nb-l). 

Therefore, the gain decoding corresponds to the decoding of predictive two-stage VQ-scalar quantization, where the 
prediction is given by the interpolated Fs/4 kHz junction matching gain. The quantization dimension is variable and is 
equal to nb. 

Decoding of the r^ stage: 

The 7-bit index < idx < 127 of the 1^^ stage 4-dimensional HF gain codebook is decoded into 4 gains (Go, Gi, G2, G3). 
A bad frame indicator bfi = BFIjGAINq in HF-256, -512 and -1024 allows to handle packet losses. If bfi = 0, these 
gains are decoded as 

(Go, Gi, G2, G3) = cb_gain_hf(idx) + mean_gain_hf 

where cb_gain_hf(/Jx) is the idx-\h code vector of the codebook cb_gain_hf. If bfi =1, a memory past_gain_hf_q is 
shifted towards -20 dB : 

past_gain_hf_q:= 0Cgain_hf * (past_gain_hf_q + 20) -20. 

where again_hf = 0-9 and the 4 gains (Go, Gi, G2, G3) are set to the same value: 

Gk = past_gain_hf_q + mean_gain_hf for ^ = 0, 1 ,2 and 3 

Then the memory past_gain_hf_q is updated as: 

past_gain_hf_q:= (Go + Gi + G2 + G3)/4 - mean_gain_hf. 

The computation of the 1^^ stage reconstruction is then given as: 

HF-256: (g^'o, g'\. fi , ^''3) = (Go, Gi, G2, G3). 

HF-512: (i\, i\, ..., i\) = (Go, Go, Gi, Gi, G2, G2, G3, G3). 

HF-1024: (g^'o, g'\, .-., ^''15) = (Go, Go, Go, Go, Gi, Gi, Gi, Gi, G2, G2, G2, G2, G3, G3, G3, G3). 

Decoding of 2^ stage: 

In TCX-256, {g'\, g'\, g'\, g'\) is simply set to (0,0,0,0) and there is no real 2"^ stage decoding. In HF-512, the 2-bit 
index < idxi < 3 of the /-th subframe, where /=0, . . ., 7, is decoded as: 

If bfi = 0, g'\ = 3 * idXi - 4.5 else g'\ = 0. 

In TCX-1024, 16 subframes 3-bit index the < idXi < 7 of the /-th subframe, where /=0, . . ., 15, is decoded as: 

If bfi = 0, g'\ = 3 * idx - 10.5 else g'\ = 0. 

In TCX-512 the magnitude of the second scalar refinement is up to ± 4.5 dB and in TCX-1024 up to ± 10.5 dB. In both 
cases, the quantization step is 3 dB. 

HF gain reconstruction: 

The gain for each subframe is then computed as: 10^' 
Buzziness reduction and energy smoothing 

The role of energy smoothing is to attenuate pulses in the time-domain HF excitation signal rHF(^), which often cause 
the audio output to sound "buzzy". Pulses are detected by checking if the absolute value I rHF(n) I > 2 * thres(n), where 
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thres{n) is an adaptive threshold corresponding to the time-domain envelope of ThfC^). The samples ThfC^) which are 
detected as pulses are limited to ± 2 * thres(n), where ± is the sign of ThfC^). 

Each sample ThfC^) of the HF excitation is filtered by a 1^^ order low-pass filter 0.02/(1 - 0.98 z^) to update thres(n). 
Note that the initial value of thres(n) (at the reset of the decoder) is 0. The amplitude of the pulse attenuation is given 
by: 

A = max( \r^^{n)\-2''thres{n) , 0.0). 

Thus, A is set to if the current sample is not detected as a pulse, which will let rHF(^) unchanged. Then, the current 
value thresin) of the adaptive threshold is changed as: 

thres(n)'= thresin) + 0.5 * A. 

Finally each sample rHF(^) is modified to: r hf('^) = ^hf(^) -A if rHF('^) ^ 0, and r'^^pin) = rHF(^) +A otherwise. 

The short-term energy variations of the HF synthesis SnY^in) are then smoothed. The energy is measured by subframe. 
The energy of each subframe is modified by up to ± 1.5 dB based on an adaptive threshold. 

For a given subframe ^hf('^), n=0,...,63, the subframe energy is calculated as 

63 



£• = 0.0001+^ 4^ (^) 



n=0 



The value t of the threshold is updated as: 
t := min(8* 1.414, O, if8<^ 

max( 8 / 1.414, t ), otherwise. 



The current subframe is then scaled by ^jt I £ : 



6.3 Stereo Signal synthesis 
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For stereo signal decoding, the mono signal is needed. First, the output of the core decoder is split into two bands , these 
two signals X^^^ (jl) and X^^-^ (ji) are fed to the low band and high band stereo decoder. 
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6.3.1 Stereo signal low-band synthesis 
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The AVQ parameters are decoded in a similar way as described in section 6.1.2, after decoding the step of spectrum de- 
shaping is performed in order to de-emphasize the spectral coefficients. 

The global gain decoding is performed according to Section 6.1. by inverting the 7-bit logarithmic quantization 
calculated in the encoder as in Section 5.5.1. The signal after inverse transform is multiplied by the global gain in order 
to produce a time domain signal y(n) . 

Decoding the balance factor is done by inverting the 7 bit scalar quantizer. In the case of mode 0, a signal envelope is 
estimated from the mono signal Xj^^^(n) and this signal is compensated for the envelope. The resulting signal is 

multiplied by the balance factor and added to the time domain signal y(n) . The estimated time domain envelope is 
used in order to shape the resulting signal and reduce the pre-echo artefact when mode is selected in the encoder. 

Adaptive overlap-add is used in order to synthesise the time domain side signal X^^^ (n) which is used to produce the 
low frequencies left and right signal X^^^ (n) , X^^^ (n) . 
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6.3.2 Stereo Signal Mid-Band synthesis 
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From core decoder 



The mono mid-band signal is filtered in order to obtain the mid-band excitation signal ^^^^^ (n) . The filter and the 

corresponding gains are decoded by using the inverse operation of the predictive multistage quantizer (MSPVQ"^) and 
the predictive 2 dimensional vector quantizer (PVQ"^). 

The filter is used to filter the excitation signal ^^^^^ (n) according to 

8 

the two channels pseudo-excitations are computed as: 

8 
^LMid (^) = gL^MMid (^)-8lTj h^MMid (^ " 0, < ^ < L^-^ + L^,,^, 

8 

eRMid (^) = gReuMid (^)+ Sr Yj h^MMid (^ - 0, < ^ < L^.^ + L^^^f^ 

Windowing and overlap add is used in norder to smooth the frame transitions. The anount of overlap is equal to 
^subfr according to the following figure 
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'^div 



"^subfr 



~^div 



The output of the overlap add sections are finally inverse filtered by the core low band signal Ipc filter 1 / A(z) to 
produce the left and right mid-band signals X^^-^ (jl) and X^^-^ (jl) . 

6.3.3 Stereo Signal High-Band synthesis 

Same as mono signal high band synthesis, the high band for each signal is delayed slightly to be aligned with the low 
and midband stereo signal 

6.3.4 Stereo output signal generation 

The low and high frequencies of the low band left and right channels are combined together according to the following 
figure 



^LMid(^) ^esp. ^RMidW 



delay 



+) >X^^(n) resp. Xj^^in) 



^LLo(^) ''''■ ^RLo(^) 



t32/5 



The obtained low band left and right channels are combined with the high band signals in order to restore the full band 
left and right channels. 

6.4 Stereo to mono conversion 

In the case the application or hardware does not support stereo output, the output of the synthesised output stereo bit 
stream needs to be mixed to mono. 

6.4.1 Low-Band synthesis 

The low band stereo output is converted to mono by omitting the stereo information in the bit stream and skipping the 
stereo decoder. Hence, the mono output is synthesised only according to Section 6.1. 

6.4.2 High-Band synthesis 

The stereo bit stream contains separate bandwidth extensions for left and right High-Band synthesis. To minimise the 
decoder complexity, the stereo to mono down mixing is done on parameter level. 
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First the High-Band gain factors for both left and right channel are decoded as explained in Section 6.2. The gain 
difference of left and right channels is calculated in dB scale. When the difference is greater than 20 dB, the LP 
synthesis filter coefficients of the higher energy channel are selected for the mono output synthesis filtering and the LP 
parameters from the lower energy channel are omitted completely. On the other hand, when the gain difference is less 
than the 20 dB threshold, the LP synthesis filter coefficients of left and right channel are averaged in ISP domain. The 
gain parameters from left and right channels are averaged in both cases. When the LP synthesis filter coefficients and 
gain factor is determined, the High-Band synthesis is done according to mono signal High-Band synthesis in 
Section 6.2. 



6.5 



Bad frame concealment 



6.5.1 



Mono 



6.5.1.1 



Mode decoding and extrapolation 



In the presence of packet losses, the decoder tries to recover the missing mode indicators from the available ones 
(including also mode indicators of previous superframes). Recall that the mode selected in a given super- frame is given 
by MODE = (mo, mi, m2, mi,) where < mk < 3 and k=0,..,3. The 26 valid modes are enumerated in Table 10. When 
frame k is missing at the receiver, bfii, is set to 1. When bfi^= 1, the value m^ is not available and has to be estimated 
from other received information. 

The mode extrapolation is essentially based on a mode repetition logic. The mode indicators from the previous super- 
frame only are reused in the extrapolation. More precisely, only the last indicator of the previous mode is used. Hence, 
the modes of the four 256-sample frames in the previous superframe are seen as (X, X, X, m.j) where the value X is not 
relevant (this value is not used here) and < m.j < 3 is the final indicator of the previous mode. Note that if m.j was 
not available, the extrapolated value of m.j is used. 

A high-level block diagram of the mode extrapolation module is given in Figure 17. 



bitstream 
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set available 

mode indicators 

(missing ones 

are set to -1) 



count number of 
pacl^et losses 



-► MODE 



-► Hlo; 



extrapolate 

missing 

mode 

indicators 



MODE 



Figure 17: High-level block diagram of mode extrapolation module 

Based on the values in BFI, the available mode indicators are set from the bits coming from the demultiplexer. The 
number of packet losses ^loss is counted as the number of bfii^ values set to 1. The mode is given by MODE = (mo, mi, 
m2, ms) with < mk < 3 when the indicator mk is available (i.e. bfii^= 0), and m^ = -I when bfii^= 1. Then, the missing 
mode indicators (for which mk = -1) are extrapolated. The logic of this mode extrapolation is shown in Figure 18. 
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BEGIN 
MODE = (rno,A77i,rn2,A7?3) 

where A7?k=-1,0,1,2 or 3 
previous mode (x,x,x, m.^ 
vO n\oss = 0, 1 , 2, 3 or 4 




MODE := (1,1,1,1) 
BFI := (1,1,1,1) 



END 

MODE = (A7?o,mi,A772,A773) 

^ where A7?k=0,1,2 or 3 

(BFI may have changed)/ 



mw■.= ^ 








J 


r 






k := /c+1 





Figure 18: Mode extrapolation logic 

The rationale behind the mode extrapolation logic in Figure 18 is as follows: 

- There exists redundancy in the definition of mode indicators. A TCX-1024 frame is described by MODE = 
(3,3,3,3), and a TCX-512 frame is described by (2,2,X,X) or (X,X,2,2). Therefore, in the absence of bit errors, 
the mode indicators describing a TCX-512 or TCX-1024 frame can be easily extrapolated in case of partial 
packet losses, when a single value mk= 2 or 3 is available. 

- The frame-erasure concealment in ACELP mode relies on the pitch delay and codebook gains of the previous 
ACELP frame. However in switched ACELP/TCX coding there is no guarantee that the frame preceding an 
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ACELP frame was also encoded by ACELP. Assuming that m^ is not available and that the extrapolation has to 
choose between m^ = or mi,= 1 , the extrapolation will select ACELP decoding (m^ = 0) only if ruk-i = 
Otherwise the ACELP parameters needed for concealment would not be up-to-date. As a consequence, under the 
above assumptions, if mk-i>0, the value m^= I will be selected. 

- If 3 packets are lost and if the only available mode indicator is mk = 3 with k =0,1,2 or 3, a mode (3,3,3,3) 
corresponding to TCX-1024 should normally be extrapolated. Yet, with the bitstream format described in 
Section 5.6, losing 3 packets out of 4 in TCX-1024 means 

1) losing roughly 3 quarters of the TCX target spectrum and 

2) having no information about the TCX global gain since the gain repetition in TCX-1024 is designed to 
perform well for up to 2 packet losses. 

As a consequence, the mode (3,3,3,3) is rather replaced by the mode (1,1,1,1) in the extrapolation when more 
than 2 packets are lost. Note that this causes the concealment of TCX-256 to be used (the synthesis will actually 
be progressively faded out). 

6.5.1 .2 TCX bad frame concealment 

Concealment of TCX256 erased frames was described in Section 6.2.1. 

In the case of a TCX 1024 partial frame loss and given that the previous decoded frame was also a TCX 1024 frame a 
spectral fill-in strategy is used in order to conceal the lost packets. The fill-in strategy assumes that since we have a case 
of two consecutive 1024-sample TCX frames, the signal is quasi stationary so that lost sub vectors can be interpolated 
from the previous frame. 

6.5.1 .2.1 Spectrum de-shaping 

Spectrum de-shaping is applied to the quantized spectrum as described in Section 5.3.5.8. In case of frame erasure, the 
de-shaping uses a prediction of the new maximum using the previously saved quantized spectrum. De-shaping is done 
according to the following steps: 

- Compute the maximum energy OldE^ax of the 8-dimensional block at position index m of the previous 1024- 
sample TCX frame 

- Compute the maximum energy E^ax of the 8-dimensional block at position index m of the current 1024-sample 
TCX frame 

It tLf^^x "^ ^l^^^max-> tiien SCt I^max ~ ^l^^^max 

- Calculate the energy Ej^ of the 8-dimensional block at position index m 

- Compute the ratio R^ = E^ax I E^ 

- Compute the value (7?^) '"^ 

- if Rm> 10, then set R^ = 10 (maximum gain of 20 dB) 

- also, ifRm>R ml then R^ = R^.i 

This allows in case of the loss of the 8-dimensional block corresponding to the maximum to use the previous maximum. 

6.5.1.2.2 Spectrum Extrapolation 

Spectrum extrapolation is applied to the quantized spectrum prior to applying the inverse FFT. Spectrum extrapolation 
consists of amplitude and phase extrapolation applied to the lost spectral coefficients. The extrapolated amplitude and 
phase are combined to form the extrapolated spectral coefficient. Combining the extrapolated and the received spectral 

coefficients is done in order to form quantized spectrum X[fc] . 
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6.5.1 .2.3 Amplitude Extrapolation 

Spectral amplitude extrapolation consists of is performed according to the following steps; 

- Compute the previous frame amplitude spectrum, oldA[k] = \oldX[k] 

- Compute the current frame spectrum, A[k] = X[k] 

- Compute the gain difference of energy of non-lost spectral coefficients between the previous and the current 
frame 



gain = 



k,S[k]^0 

Y,oldS[kf 

k,S[k]^0 



Extrapolate the amplitude of the missing spectral coefficients using 
if (lostfk]) A[k] = gain • oldA[k] 



6.5.1 .2.4 Phase Extrapolation 

r Known phase 



^^^ r 



Predicted-extrapolated 
phase 




K+N bin 

old(p(K + N) 



Phase extrapolation uses the principle of group delay conservation for quasi-stationary signals. First the group delay is 
estimated on the previous frame and then used in the current frame in order to extrapolate the phase on the missing 
spectral coefficients. The estimation of the group delay is done by computing 

Aold(p(k) = old(p{k) - old(p{k - 1) 
The phase of the missing spectral coefficients 0{k) is computed by using the following recursive algorithm 

0{k) = 0{k - 1) + Aoldcpik) + A(p,, k = K + l...,K + N -I 
where 

Acp^ =(1/N)' ((p(K + N)- old(p(K + N)- (p(K) + old(p{K)) 



ETSI 



3GPP TS 26.290 version 9.0.0 Release 9 70 ETSI TS 126 290 V9.0.0 (2010-01) 

0{K) — (p(K) is used to start the recursion., and K,.K + N are received (non lost) bins. 

6.5.2 Stereo 

The stereo error concealment is controlled by the bad frame indicators bfi^ , k = 0. . .3. In response to the bad frame 
indicators of the present super frame together with some bad frame indicator history proper actions are taken mitigating 
the perceptual impact of bad frames. Particular error mitigation actions are taken on the stereo low-band, the mid-band, 
and the high-band. 

6.5.2.1 Low-band 

Balance factor 

The balance factor to be used for the derivation of the side signal is not available depending on bfii^ and on the stereo 
TCX frame length, i.e. if 

bfii,= 1, k = 0. . .3 in case of 256-sample stereo TCX frames, 

bfi^= 1, k = 0, 2 in case of 512-sample stereo TCX frames, or 

bfi^= 1, k = in case of 1024-sample stereo TCX frames. 

In this case, the balance factor is derived from the balance factor of the previous stereo TCX frame, however, attenuated 
by 0.9. 

For the case of a future frame loss, the balance factor of the present stereo TCX frame is stored in a history buffer. 

Side signal error signal 

The side signal error signal is derived using the TCX decoder and the associated bad frame concealment described 
above (6.6.1.3). Input to the TCX bad frame concealment is a flag, signalling if any of the frames associated with the 
present stereo TCX frame is bad. 

Side signal 

Stereo TCX frames of size 512 samples and 1024 samples are reconstructed as in the case without bad frames, however 
using the balance factor and side signal error signal derived as specified above. 

Bad stereo TCX frames of size 256 samples are, however, reconstructed differently. A parametric model with transfer 
function 



H{z) = Yh(i)-z-\P=^ 



is applied to the windowed mono signal for reconstructing a substitution signal for the side signal. The filter coefficients 
are taken from a state memory and are always derived during preceding stereo TCX frames if the associated bfi^ flags 
are equal to zero. The coefficients are calculated by solving the following equation system: 



where R is a Toeplitz matrix of autocorrelations r^^ of the windowed mono signal: 

R^^-kjJ-k)l j,ke[O...P], 

and where r^^ is a vector of cross-correlations r^s of the windowed mono signal and the side signal.* 

r^=[r„s(k)l kG[O...P]. 
Left/right signal reconstruction 



ETSI 



3GPP TS 26.290 version 9.0.0 Release 9 71 ETSI TS 1 26 290 V9.0.0 (201 0-01 ) 

The side signal used for left/right signal reconstruction is attenuated in case of severe frame loss conditions of an 
estimated frame loss rate of greater than 1%. Using an estimate / of the present average frame loss rate, an attenuation 
factor a is derived according to the following formula: 

a = l- min(0.7,17.5 • (/ - 0.01)) , 

where, in addition, a is limited to be within the range of 0. . . 1 . 

Before reconstructing left and right signals, the side signal is multiplied with factor a. 

The average frame loss rate is estimated according to the following algorithm. 

A first estimate /is calculated according to 



f= — 'Y.'^j'bfi_buf(-j),N=500, 



7=0 

where Wj is a weighting factor defined as 

w. =min(l,1.5-— ), 

' N 

and bfi_buf is a buffer comprising the N most recent flags bfii^. 

The final frame loss rate estimate is then obtained by AR-1 filtering: 

/ = 0.9-7' + 0.1-/, 
where / is the frame loss estimate calculated during processing of the preceding frame. 

6.5.2.2 Mid-band 

The mid-band synthesis is performed on every frame. When a frame is lost the parameters of the mid-band decoder are 
extrapolated by using the predictive decoders fed with a zero error signal. This implies that the error will propagate to 
few frames which does not impact the overall quality. The extrapolated parameters are the filter coefficients and the 
channel gains and are computed as: 



8l (frame) = 0.5- g^ (frame - 1), 
gj^ (frame) = 0.5 • g^ (frame - 1), 
b. (frame) = 0.5 • b. (frame - 1), / = 0, • • • ,8 



6.6 Output signal generation 



The decoder output signal(s) are generated by combining the low and high band signal to produce full band signals. 
This operation is the inverse of the encoder band-splitting operation described in section 5.1. The following figure 
shows how the operation is performed. 
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Xfj(n) 



1024 samples 



Xiin) 



T2 



1024 samples 



t2 



HP 



Output signal Fs kHz 



LP 



2048 samples 



The exact same filters used in the encoder are re-used in the decoder. Furthermore, if the desired output sampling rate is 
different from the internal sampling rate, then a resampling operation is preformed which is the reverse operation of that 
performed in the encoder. 



Input signal 
FskHz 



t180 



LP 
1/180 



iK 



Output signal 
180Fs/KkHz 



7 Detailed bit allocation of the Extended AMR-WB 

codec 

The detailed allocation of the bits in the AMR-WB+ audio encoder is shown for each frame type in tables 14-17 for 
mono and tables 18-20 for stereo. These tables show the order of the bits produced by the audio encoder. Note that the 
most significant bit (MSB) of each codec parameter is always sent first. For TCX512 frames, the frame is split in two 
equal packets. For TCX1024 frames, the frame is split in four equal packets. The splitting of TCX512 and TCX1024 
frames in several packets is explained in Section 5.6.1. 
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Table 14: Source encoder output parameters in order of occurrence and bit allocation within the 

audio frame of ACELP coding type 





Bits (MSB-LSB) 


Description 


480 
bits/frame 


416 
bits/frame 


384 
bits/frame 


336 
bits/frame 


304 
bits/frame 


272 
bits/frame 


240 
bits/frame 


208 
bits/frame 


IVIode bits 


bO-b1 


bO-b1 


bO-b1 


bO-b1 


bO-b1 


bO-b1 


bO-b1 


bO-b1 


1'MSPsubvec 


b2-b9 


b2-b9 


b2-b9 


b2-b9 


b2-b9 


b2-b9 


b2-b9 


b2-b9 


2"^ ISP subvec 


b10-b17 


b10-b17 


b10-b17 


b10-b17 


b10-b17 


b10-b17 


b10-b17 


b10-b17 


3'^ ISP subvec 


b18-b23 


b18-b23 


b18-b23 


b18-b23 


b18-b23 


b18-b23 


b18-b23 


b18-b23 


4^' ISP subvecr 


b24 - b30 


b24 - b30 


b24 - b30 


b24 - b30 


b24 - b30 


b24 - b30 


b24 - b30 


b24 - b30 


5^" ISP subvec 


b31 -b37 


b31 -b37 


b31 -b37 


b31 -b37 


b31 -b37 


b31 -b37 


b31 -b37 


b31 -b37 


6^' ISP subvec 


b38 - b42 


b38 - b42 


b38 - b42 


b38 - b42 


b38 - b42 


b38 - b42 


b38 - b42 


b38 - b42 


/" ISP subvec 


b43 - b47 


b43 - b47 


b43 - b47 


b43 - b47 


b43 - b47 


b43 - b47 


b43 - b47 


b43 - b47 


index of mean energy 


b48 - b49 


b48 - b49 


b48 - b49 


b48 - b49 


b48 - b49 


b48 - b49 


b48 - b49 


b48 - b49 


subframe 1 


Adaptive CB index 


b50 - b58 


b50 - b58 


b50 - b58 


b50 - b58 


b50 - b58 


b50 - b58 


b50 - b58 


b50 - b58 


LTP-filtering-flag 


b59 


b59 


b59 


b59 


b59 


b59 


b59 


b59 


Algebraic CB indices 


b60-b147 


b60-b131 


b60-b123 


b60-b111 


b60-b103 


b60 - b95 


b60 - b87 


b60 - b79 


codebook gains 


b148-b154 


b132-b138 


b124-b130 


b112-b118 


b104-b110 


b96-b102 


b88 - b94 


b80 - b86 


subframe 2 


Adaptive CB index 


b155-b160 


b139-b144 


b131 -b136 


b119-b124 


b111 -b116 


b103-b108 


b95-b100 


b87 - b92 


LTP-filtering-flag 


b161 


b145 


b137 


b125 


b117 


b109 


b101 


b93 


Algebraic CB indices 


b162-b249 


b146-b217 


b138-b201 


b126-b177 


b118-b161 


b110-b145 


b102-b129 


b94-b113 


codebook gains 


b250 - b256 


b218-b224 


b202 - b208 


b178-b184 


b162-b168 


b146-b152 


b130-b136 


b114-b120 


subframe 3 


Adaptive CB index 


b257 - b265 


b225- b233 


b209-b217 


b185-b193 


b169-b177 


b153-b161 


b137-b145 


b121 -b129 


LTP-filtering-flag 


b266 


b234 


b218 


b194 


b178 


b162 


b146 


b130 


Algebraic CB indices 


b267 - b354 


b235 - b306 


b219-b282 


b195-b246 


b179-b222 


b163-b198 


b147-b174 


b131 -b150 


codebook gains 


b355-b361 


b307-b313 


b283 - b289 


b247 - b253 


b223 - b229 


b199-b205 


b175-b181 


b151 -b157 


subframe 4 


Adaptive CB index 


b362 - b367 


b314-b319 


b290 - b295 


b254 - b259 


b230 - b235 


b206 - b21 1 


b182-b187 


b158-b163 


LTP-filtering-flag 


b368 


b320 


b296 


b260 


b236 


b212 


b188 


b164 


Algebraic CB indices 


b369 - b456 


b321 - b392 


b297 - b360 


b261 -b312 


b237 - b280 


b213-b248 


b189-b216 


b165-b184 


codebook gains 


b457 - b463 


b493 - b399 


b361 - b367 


b313-b319 


b281 - b287 


b249 - b255 


b217-b223 


b185-b191 


Bandwidth extension 


Index of HF ISP 


b464 - b472 


b400 - b408 


b368 - b376 


b320 - b328 


b288 - b296 


b256 - b264 


b224 - b232 


b192-b200 


Index of HF gain 


b473 - b479 


b409-b415 


b377 - b383 


b329- b335 


b297 - b303 


b265 - b271 


b233 - b239 


b201-b207 



Table 15: Source encoder output parameters in order of occurrence and bit allocation within the 

audio frame of TCX256 frame type 





Bits (MSB-LSB) 


Description 


480 
bits/frame 


416 
bits/frame 


384 
bits/frame 


336 
bits/frame 


304 
bits/frame 


272 
bits/frame 


240 
bits/frame 


208 
bits/frame 


mode bits 


bO-b1 


bO-b1 


bO-b1 


bO-b1 


bO-b1 


bO-b1 


bO-b1 


bO-b1 


1'MSP subvec 


b2-b9 


b2-b9 


b2-b9 


b2-b9 


b2-b9 


b2-b9 


b2-b9 


b2-b9 


2"' ISP subvec 


b10-b17 


b10-b17 


b10-b17 


b10-b17 


b10-b17 


b10-b17 


b10-b17 


b10-b17 


3'^ ISP subvec 


b18-b23 


b18-b23 


b18-b23 


b18-b23 


b18-b23 


b18-b23 


b18-b23 


b18-b23 


4'" ISP subvecr 


b24 - b30 


b24 - b30 


b24 - b30 


b24 - b30 


b24 - b30 


b24 - b30 


b24 - b30 


b24 - b30 


5^' ISP subvec 


b31 -b37 


b31 -b37 


b31 -b37 


b31 -b37 


b31 -b37 


b31 -b37 


b31 -b37 


b31 -b37 


6^" ISP subvec 


b38 - b42 


b38 - b42 


b38 - b42 


b38 - b42 


b38 - b42 


b38 - b42 


b38 - b42 


b38 - b42 


/' ISP subvec 


b43 - b47 


b43 - b47 


b43 - b47 


b43 - b47 


b43 - b47 


b43 - b47 


b43 - b47 


b43 - b47 


Noise factor 


b48-b50 


b48-b50 


b48-b50 


b48-b50 


b48-b50 


b48-b50 


b48-b50 


b48-b50 


Global gain 


b51 -b57 


b51 -b57 


b51 -b57 


b51 -b57 


b51 -b57 


b51 -b57 


b51 -b57 


b51 -b57 


Algebraic VQ 


b58 - b463 


b58 - b399 


b58 - b367 


b58-b319 


b58 - b287 


b58 - b255 


b58 - b223 


b58-b191 


Bandwidth extension 


Index of HF ISP 


b464 - b472 


b400 - b408 


b368 - b376 


b320 - b328 


b288 - b296 


b256 - b264 


b224 - b232 


b192-b200 


Index of HF 
gain 


b473 - b479 


b409-b415 


b377 - b383 


b329- b335 


b297 - b303 


b265 - b271 


b233 - b239 


b201 - b207 
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Table 16a: Source encoder output parameters in order of occurrence and bit allocation within the 

audio frame of TCX512 frame type - First Packet 





Bits (MSB-LSB) 


Description 


480 
bits/frame 


416 
bits/frame 


384 
bits/frame 


336 
bits/frame 


304 
bits/frame 


272 
bits/frame 


240 
bits/frame 


208 
bits/frame 


mode bits 


bO-b1 


bO-b1 


bO-b1 


bO-b1 


bO-b1 


bO-b1 


bO-b1 


bO-b1 


1'MSPsubvec 


b2-b9 


b2-b9 


b2-b9 


b2-b9 


b2-b9 


b2-b9 


b2-b9 


b2-b9 


2"' ISP subvec 


b10-b17 


b10-b17 


b10-b17 


b10-b17 


b10-b17 


b10-b17 


b10-b17 


b10-b17 


Noise factor 


b18-b20 


b18-b20 


b18-b20 


b18-b20 


b18-b20 


b18-b20 


b18-b20 


b18-b20 


Global gain 


b21 -b27 


b21 -b27 


b21 -b27 


b21 -b27 


b21 -b27 


b21 -b27 


b21 -b27 


b21 -b27 


Split Algebraic 
VQ 


b28 - b463 


b28 - b399 


b28 - b367 


b28-b319 


b28 - b287 


b28 - b255 


b28 - b223 


b28-b191 


Bandwidth extension 


Index of HF ISP 


b464 - b472 


b400 - b408 


b368 - b376 


b320 - b328 


b288 - b296 


b256 - b264 


b224 - b232 


b192-b200 


Index of HF 
gain 


b473- b479 


b409-b415 


b377 - b383 


b329- b335 


b297 - b303 


b265 - b271 


b233 - b239 


b201 - b207 



Table 16b: Source encoder output parameters in order of occurrence and bit allocation within the 

audio frame of TCX512 frame type - Second Packet 





Bits (MSB-LSB) 


Description 


480 
bits/frame 


416 
bits/frame 


384 
bits/frame 


336 
bits/frame 


304 
bits/frame 


272 
bits/frame 


240 
bits/frame 


208 
bits/frame 


mode bits 


bO-b1 


bO-b1 


bO-b1 


bO-b1 


bO-b1 


bO-b1 


bO-b1 


bO-b1 


3'' ISP subvec 


b2-b7 


b2-b7 


b2-b7 


b2-b7 


b2-b7 


b2-b7 


b2-b7 


b2-b7 


4'" ISP subvecr 


b8-b14 


b8-b14 


b8-b14 


b8-b14 


b8-b14 


b8-b14 


b8-b14 


b8-b14 


5^' ISP subvec 


b15-b21 


b15-b21 


b15-b21 


b15-b21 


b15-b21 


b15-b21 


b15-b21 


b15-b21 


6^" ISP subvec 


b22 - b26 


b22 - b26 


b22 - b26 


b22 - b26 


b22 - b26 


b22 - b26 


b22 - b26 


b22 - b26 


/' ISP subvec 


b27-b31 


b27-b31 


b27-b31 


b27-b31 


b27-b31 


b27-b31 


b27-b31 


b27-b31 


Gain 

redundancy (6 

MSBs) 


b32-b37 


b32-b37 


b32-b37 


b32-b37 


b32-b37 


b32-b37 


b32-b37 


b32-b37 


Split Algebraic 
VQ 


b38 - b463 


b38 - b399 


b38 - b367 


b38-b319 


b38 - b287 


b38 - b255 


b38 - b223 


b38-b191 


Bandwidth extension 


Gain correction 
8x2 bits 


b464-b479 


b400-b415 


b368-b383 


b320-b335 


b288-b303 


b256-b271 


b224-b239 


b192-b207 



Table 17a: Source encoder output parameters in order of occurrence and bit allocation within the 

audio frame of TCX1024 frame type - First Packet 





Bits (MSB-LSB) 


Description 


480 
bits/frame 


416 
bits/frame 


384 
bits/frame 


336 
bits/frame 


304 
bits/frame 


272 
bits/frame 


240 
bits/frame 


208 

bits/frame 


mode bits 


bO-b1 


bO-b1 


bO-b1 


bO-b1 


bO-b1 


bO-b1 


bO-b1 


bO-b1 


1 'MSP subvec 


b2-b9 


b2-b9 


b2-b9 


b2-b9 


b2-b9 


b2-b9 


b2-b9 


b2-b9 


2"' ISP subvec 


b10-b17 


b10-b17 


b10-b17 


b10-b17 


b10-b17 


b10-b17 


b10-b17 


b10-b17 


Global gain 


b18-b24 


b18-b24 


b18-b24 


b18-b24 


b18-b24 


b18-b24 


b18-b24 


b18-b24 


Split Algebraic 
VQ 


b25 - b463 


b25 - b399 


b25 - b367 


b25-b319 


b25 - b287 


b25 - b255 


b25 - b223 


b25-b191 


Bandwidth extension 


Index of HF ISP 


b464 - b472 


b400 - b408 


b368 - b376 


b320 - b328 


b288 - b296 


b256 - b264 


b224 - b232 


b192-b200 


Index of HF 
gain 


b473 - b479 


b409-b415 


b377 - b383 


b329- b335 


b297 - b303 


b265 - b271 


b233 - b239 


b201 - b207 
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Table 17b: Source encoder output parameters in order of occurrence and bit allocation within the 
audio frame of TCX1024 frame type - Second packet 





Bits (MSB-LSB) 


Description 


480 
bits/frame 


416 
bits/frame 


384 
bits/frame 


336 
bits/frame 


304 
bits/frame 


272 
bits/frame 


240 
bits/frame 


208 
bits/frame 


mode bits 


bO-bl 


bO-bl 


bO-bl 


bO-bl 


bO-bl 


bO-bl 


bO-bl 


bO-bl 


3'^ ISP subvec 


b2-b7 


b2-b7 


b2-b7 


b2-b7 


b2-b7 


b2-b7 


b2-b7 


b2-b7 


Noise factor 


b8-b10 


b8-b10 


b8-b10 


b8-b10 


b8-b10 


b8-b10 


b8-b10 


b8-b10 


Global gain 
parity 


b11 -b13 


b11 -b13 


b11 -b13 


b11 -b13 


b11 -b13 


b11 -b13 


b11 -b13 


b11 -b13 


Split Algebraic 
VQ 


b14-b463 


b14-b399 


b14-b367 


b14-b319 


b14-b287 


b14-b255 


b14-b223 


b14-b191 


Bandwidth extension 


Gain correction 

8x2 bits 

(MSBs 1'^ 8 

subframes) 


b464-b479 


b400-b415 


b368-b383 


b320-b335 


b288-b303 


b256-b271 


b224-b239 


b192-b207 



Table 17c: Source encoder output parameters in order of occurrence and bit allocation within the 

audio frame of TCX1024 frame type - Third packet 





Bits (MSB-LSB) 


Description 


480 
bits/frame 


416 
bits/frame 


384 
bits/frame 


336 
bits/frame 


304 
bits/frame 


272 
bits/frame 


240 
bits/frame 


208 
bits/frame 


mode bits 


bO-bl 


bO-bl 


bO-bl 


bO-bl 


bO-bl 


bO-bl 


bO-bl 


bO-bl 


4^' ISP subvecr 


b2-b8 


b2-b8 


b2-b8 


b2-b8 


b2-b8 


b2-b8 


b2-b8 


b2-b8 


6'" ISP subvec 


b9-b13 


b9-b13 


b9-b13 


b9-b13 


b9-b13 


b9-b13 


b9-b13 


b9-b13 


Global gain 
redundancy 


b14-b16 


b14-b16 


b14-b16 


b14-b16 


b14-b16 


b14-b16 


b14-b16 


b14-b16 


Split Algebraic 
VQ 


b17-b463 


b17-b399 


b17-b367 


b17-b319 


b17-b287 


b17-b255 


b17-b223 


b17-b191 


Bandwidth extension 


Gain correction 

8x2 bits 

(MSBs 2"^ 8 

subframes) 


b464-b479 


b400-b415 


b368-b383 


b320-b335 


b288-b303 


b256-b271 


b224-b239 


b192-b207 



Table 17d: Source encoder output parameters in order of occurrence and bit allocation within the 

audio frame of TCX1024 frame type - Fourth packet 





Bits (MSB-LSB) 


Description 


480 
bits/frame 


416 
bits/frame 


384 
bits/frame 


336 
bits/frame 


304 
bits/frame 


272 
bits/frame 


240 
bits/frame 


208 
bits/frame 


mode bits 


bO-bl 


bO-bl 


bO-bl 


bO-bl 


bO-bl 


bO-bl 


bO-bl 


bO-bl 


5'" ISP subvec 


b2-b8 


b2-b8 


b2-b8 


b2-b8 


b2-b8 


b2-b8 


b2-b8 


b2-b8 


/" ISP subvec 


b9-b13 


b9-b13 


b9-b13 


b9-b13 


b9-b13 


b9-b13 


b9-b13 


b9-b13 


Global gain 
redundancy 


b14-b16 


b14-b16 


b14-b16 


b14-b16 


b14-b16 


b14-b16 


b14-b16 


b14-b16 


Split Algebraic 
VQ 


b17-b463 


b17-b399 


b17-b367 


b17-b319 


b17-b287 


b17-b255 


b17-b223 


b17-b191 


Bandwidth extension 


Gain correction 

16x1 bits 

(LSB16 

subframes) 


b464-b479 


b400-b415 


b368-b383 


b320-b335 


b288-b303 


b256-b271 


b224-b239 


b192-b207 



Ni is the number of bits per frame allocated for the low and midband and is calculated according to 
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Table 18: Stereo encoder output parameters in order of occurrence and bit allocation within the 

audio frame of TCX48 frame type, mode and 1 





Bits (MSB-LSB) 


Description 


N bits/frame <=76 


N bits/frame > 76 


IVIidband stereo 


IVIidband filter 


b0-b3 


b0-b6 


IVIidband gain 


b4-b5 


b7-b1 1 


Lowband stereo 


Mode bits 


b6-b7 


b12-b13 


reserved 


b8 


b14 


Balance factor 


B9-b15 


b15-b21 


Global gain 


b16-b22 


b22-b28 


Algebraic VQ 


b23 - bNi 


b29- bNi 



Table 19a: Stereo encoder output parameters in order of occurrence and bit allocation within the 
audio frame of TCX96 frame type, mode 2 - First packet 





Bits (MSB-LSB) 


Description 


N bits/frame <=76 


N bits/frame > 76 


Midband stereo 


Midband filter 


bO-bS 


b0-b6 


Midband gain 


b4-b5 


b7-b1 1 


Lowband stereo 


Mode bits 


b6-b7 


b12-b13 


reserved 


b8 


b14 


Balance factor 


B9-b15 


b15-b21 


Algebraic VQ 


b16-bNi 


b22- bNi 



Table 19b: Stereo encoder output parameters in order of occurrence and bit allocation within the 
audio frame of TCX96 frame type, mode 2 - Second packet 





Bits (MSB-LSB) 


Description 


N bits/frame <=76 


N bits/frame > 76 


Midband stereo 


Midband filter 


bO-bS 


b0-b6 


Midband gain 


b4-b5 


b7-b1 1 


Lowband stereo 


Mode bits 


b6-b7 


b12-b13 


reserved 


b8 


b14 


Global gain 


b9-b15 


b15-b21 


Algebraic VQ 


b16-bNi 


b22- bNi 
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Table 20a: Stereo encoder output parameters in order of occurrence and bit allocation within the 
audio frame of TCX96 frame type, mode 3 - First packet 





Bits (MSB-LSB) 


Description 


N bits/frame <=76 


N bits/frame > 76 


IVIidband stereo 


IVIidband filter 


b0-b3 


b0-b6 


IVIidband gain 


b4-b5 


b7-b1 1 


Lowband stereo 


Mode bits 


b6-b7 


b12-b13 


reserved 


b8 


b14 


Balance factor 


b9-b15 


b15-b21 


Algebraic VQ 


b16-bNi 


b22- bNi 



Table 20b: Stereo encoder output parameters in order of occurrence and bit allocation within the 
audio frame of TCX96 frame type, mode 3 - Second packet 





Bits (MSB-LSB) 


Description 


N bits/frame <=76 


N bits/frame > 76 


Midband stereo 


Midband filter 


bO-bS 


b0-b6 


Midband gain 


b4-b5 


b7-b1 1 


Lowband stereo 


Mode bits 


b6-b7 


b12-b13 


reserved 


b8 


b14 


Algebraic VQ 


b9-bNi 


b15-bNi 



Table 20c: Stereo encoder output parameters in order of occurrence and bit allocation within the 
audio frame of TCX96 frame type, mode 3 - Third packet 





Bits (MSB-LSB) 


Description 


N bits/frame <=76 


N bits/frame > 76 


Midband stereo 


Midband filter 


b0-b3 


b0-b6 


Midband gain 


b4-b5 


b7-b1 1 


Lowband stereo 


Mode bits 


b6-b7 


b12-b13 


reserved 


b8 


b14 


Global gain 


B9-b15 


b15-b21 


Algebraic VQ 


b16-bNi 


b22- bNi 



Table 20d: Stereo encoder output parameters in order of occurrence and bit allocation within the 
audio frame of TCX96 frame type, mode 3 - Fourth packet 





Bits (MSB-LSB) 


Description 


N bits/frame <=76 


N bits/frame > 76 


Midband stereo 


Midband filter 


bO-bS 


b0-b6 


Midband gain 


b4-b5 


b7-b1 1 


Lowband stereo 


Mode bits 


b6-b7 


b12-b13 


reserved 


b8 


b14 


Algebraic VQ 


b9-bNi 


b15-bNi 
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8 Storage and Transport Interface formats 

The AMR-WB+ codec storage and transport interface formats are described in this section. 



8.1 



Available Modes and Bitrates 



The AMR-WB+ format contains the AMR-WB modes and a set of AMR-WB+ extension modes. 
The AMR-WB + codec includes the AMR-WB modes, as shown in Table 21 below. 

Table 21 : AMR-WB+ modes. 



Index 


Mode 


Sampling 
rate (kHz) 


Mono/Stereo 


Number of data octets 
per frame (AMR-WB 
modes zero-padded) 





AMR-WB 6.60 kbit/s 


16 


Mono 


17 


1 


AMR-WB 8.85 kbit/s 


16 


Mono 


23 


2 


AMR-WB 12.65 kbit/s 


16 


Mono 


32 


3 


AMR-WB 14.25 kbit/s 


16 


Mono 


36 


4 


AMR-WB 15.85 kbit/s 


16 


Mono 


40 


5 


AMR-WB 18.25 kbit/s 


16 


Mono 


46 


6 


AMR-WB 19.85 kbit/s 


16 


Mono 


50 


7 


AMR-WB 23.05 kbit/s 


16 


Mono 


58 


8 


AMR-WB 23.85 kbit/s 


16 


Mono 


60 


9 


AMR-WB SID 


16 


Mono 


5 


10 


AMR-WB+ 13.6 kbit/s 


16/24 


Mono 


34 


11 


AMR-WB+ 18 kbit/s 


16/24 


Stereo 


45 


12 


AMR-WB+ 24 kbit/s 


16/24 


Mono 


60 


13 


AMR-WB+ 24 kbit/s 


16/24 


Stereo 


60 


14 


FRAME_ERASURE 


- 


- 





15 


NO_DATA 


- 


- 






There are four special extension modes (Index 10-13 in table 21) that have a fixed internal sampling frequency (25600 
Hz) and audio input frequencies (16 or 24 kHz). These modes share the property with the AMR-WB modes that each 
frame is only capable of representing 20 ms. 

Besides the AMR-WB + operation according to the modes specified in table 21, AMR-WB + operation is specified by 
three parameters: mono bit-rate as given in Table 22, stereo bit-rate as given in Table 23, and internal sampling 
frequency (ISF) as given in Table 24. 

Table 22: Mono rate indices. 



Mono 
Index 


Mono rate 


Bit rate at 25.6 
kHz ISF 


Octets per frame 





AMR-WB+ 208 bit/frame 


10.4 kbit/s 


26 


1 


AMR-WB+ 240 bit/frame 


12 kbit/s 


30 


2 


AMR-WB+ 272 bit/frame 


13.6 kbit/s 


34 


3 


AMR-WB+ 304 bit/frame 


15.2 kbit/s 


38 


4 


AMR-WB+ 336 bit/frame 


16.8 kbit/s 


42 


5 


AMR-WB+ 384 bit/frame 


19.2 kbit/s 


48 


6 


AMR-WB+ 416 bit/frame 


20.8 kbit/s 


52 


7 


AMR-WB+ 480 bit/frame 


24 kbit/s 


60 
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Table 23: Stereo rate indices. 



Stereo index 


Stereo extension 
rar^(bits/frame) 


Stereo rate for ISF 
of 25.6 kHz 


Number of data 
octets per frame 





40 bits/frame 


2.0 kbit/s 


5 


1 


48 bits/frame 


2.4 kbit/s 


6 


2 


56 bits/frame 


2.8 kbit/s 


7 


3 


64 bits/frame 


3.2 kbit/s 


8 


4 


72 bits/frame 


3.6 kbit/s 


9 


5 


80 bits/frame 


4.0 kbit/s 


10 


6 


88 bits/frame 


4.4 kbit/s 


11 


7 


96 bits/frame 


4.8 kbit/s 


12 


8 


104 bits/frame 


5.2 kbit/s 


13 


9 


112 bits/frame 


5.6 kbit/s 


14 


10 


120 bits/frame 


6.0 kbit/s 


15 


11 


128 bits/frame 


6.4 kbit/s 


16 


12 


136 bits/frame 


6.8 kbit/s 


17 


13 


144 bits/frame 


7.2 kbit/s 


18 


14 


152 bits/frame 


7.6 kbit/s 


19 


15 


160 bits/frame 


8.0 kbit/s 


20 



It is to be noted that the number of samples each frame corresponds to is always the same but the duration of each frame 
varies depending on the internal sampling frequency. There is no preferred sampling frequency for the codec to operate 
at, but in order to limit the possible settings for an effective transmission, the format supports the sampling frequencies 
given in Table 24. . Herein, index is used for AMR-WB and the 4 extension modes of Table 21. 



ETSI 



3GPP TS 26.290 version 9.0.0 Release 9 



80 



ETSI TS 126 290 V9.0.0 (2010-01) 



Table 24: Internal sampling frequencies and corresponding frame lengths in time 



ISF 
Index 


Internal 
Sampling Rate 

(Hz) 


Frame duration (ms) 


Bit Rate 

factor 





N/A 


20 


N/A 


1 


12800 


40 


Yi 


2 


14400 


35.55 


9/16 


3 


16000 


32 


5/8 


4 


17067 


30 


2/3 


5 


19200 


26.67 


3/4 


6 


21333 


24 


5/6 


7 


24000 


21.33 


15/16 


8 


25600 


20 


1 


9 


28800 


17.78 


9/8 


10 


32000 


16 


5/4 


11 


34133 


15 


4/3 


12 


36000 


14.22 


45/32 


13 


38400 


13.33 


3/2 



The bit-rate will be dependent on the internal sampling frequency. The last column of Table 24 indicates which 
multiplication factor, any bit-rate value for 25600 Hz internal sampling factor should be converted with. The ISF index 
is carried in the bitstream format to indicate which internal sampling frequency is used for each AMR-WB+ encoded 
frame. 

The frame type is used to identify the content of an AMR-WB+ encoded frame. This type indicates if it is; an AMR- 
WB mode, Comfort noise, NO_DATA, AMR-WB+ core mode in mono usage, or a combination of a core mode and a 
stereo mode. The frame types are presented in Table 25 below. The core mode and stereo mode index values are 
according to Table 22 and 23 respectively. The bit-rate value assumes an internal sampling frequency of 25600 Hz. 
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Table 25: Normative frame type table. Bit-rates assumes 25600 Hz internal sampling frequency. 



Frame type 


Core 
mode 


Stereo 
mode 


Bit rate 


Octets per 
frame 


0-15 


As specified in Table 21 


16 





None 


10.4 


26 


17 


1 


None 


12.0 


30 


18 


2 


None 


13.6 


34 


19 


3 


None 


15.2 


38 


20 


4 


None 


16.8 


42 


21 


5 


None 


19.2 


48 


22 


6 


None 


20.8 


52 


23 


7 


None 


24.0 


60 


24 








12.4 


31 


25 





1 


12.8 


32 


26 





4 


14 


35 


27 


1 


1 


14.4 


36 


28 


1 


3 


15.2 


38 


29 


1 


5 


16 


40 


30 


2 


2 


16.4 


41 


31 


2 


4 


17.2 


43 


32 


2 


6 


18 


45 


33 


3 


3 


18.4 


46 


34 


3 


5 


19.2 


48 


35 


3 


7 


20 


50 


36 


4 


4 


20.4 


51 


37 


4 


6 


21.2 


53 


38 


4 


9 


22.4 


56 


39 


5 


5 


23.2 


58 


40 


5 


7 


24 


60 


41 


5 


11 


25.6 


64 


42 


6 


8 


26 


65 


43 


6 


10 


26.8 


67 


44 


6 


15 


28.8 


72 


45 


7 


9 


29.6 


74 


46 


7 


10 


30 


75 


47 


7 


15 


32 


80 


48-127 


Reserved 



8.2 AMR-WB+ Transport Interface Format 

The transport interface format serves as an intermediate interface to the transport format. The transport interface frame 
contains a two-octet header followed by data octets. 

The header in each frame contains the following two octets. 





MSB 




LSB 


Octet 


bits 


bit? 


bite 


bits 


bit 4 


bits 


bit 2 


bit1 


1 





Frame type (FT) 


^_2 


^^i^^ 





^^^^^^^^^_ ISF mode (5 bits) ^^^^^^^^^_ 
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Frame type (FT) (7 bits): Indicates the frame type setting of the codec used for the corresponding frame (the 
combination of AMR-WB+ core and stereo mode, the AMR-WB mode, or comfort noise, as specified by Table 25 
above). 

Transport Frame Index (TFI) (2 bits): An index from (first) to 3 (last) indicating this transport frame" s position in 
the superframe. 

ISF index (5 bits): Indicates the internal sampling frequency employed for the corresponding frame. The index values 
correspond to internal sampling frequency as specified in Table 24 above. This field SHALL be set to for operation 
according to the AMR-WB+ modes defined in table 21 (Frame types 0-13). 

FT=14 (AUDIO_LOST) is used to indicate frames that are lost. NO_DATA (FT=15) frame could mean either that there 
is no data produced by the audio encoder for that frame or that no data for that frame is transmitted in the current packet 
(i.e., valid data for that frame could be sent in either an earlier or later packet). The duration for these non-included 
frames is dependent on the internal sampling frequency indicated by the ISF mode field. 

For operation according to FT 0-13 the ISF field shall be set and has no meaning. The frame length for that operation 
is fixed to 20 ms in time. 

If receiving a frame with an FT value not defined the whole frame SHOULD be discarded and assumed erased. 

The AMR-WB+ SCR/DTX is identical with AMR-WB SCR/DTX described in [8] and SHALL only be used in 
combination with the AMR-WB modes (0-8). 

The audio data follows the header octets. The number of data octets per frame corresponding to a certain frame type is 
given in Table 25. 

Example 

The following diagram (Table 26) shows a frame of AMR-WB + using 14 kbit/s frame type (FT=26) with a frame 
length of 35 octets (280 bits). The internal sampling frequency in this example is 25.6 kHz (ISF mode = 8). FT 26 
corresponds to mono mode (208 bits/frame) and stereo mode 4 (72 bits/frame). The frame is the first frame in the 
superframe (TFI=0). 

The data octets are placed according to the detailed bit allocation given in tables 14 to 20. The first bit of the AMR- 
WB+ data bO is placed in bit 8 of octet 3. 

Table 26: AMR-WB+ transport interface format for 14 kbit/s operation with ISF mode 8 (bit rate 

factor=1). 





MSB 




LSB 


Octet 


bit 8 


bit? 


bite 


bits 


Bit 4 


bit 3 


bit 2 


bit1 


1 


FT = 26 











1 


1 





1 





2 


IF 


=0 






ISF 


= 8 


















1 











3 




























b6 


b7 


4..27 


































28 






























b206 


b207 


29 






























s6 


s7 


30..36 


































37 






























S70 


S71 



ETSI 



3GPP TS 26.290 version 9.0.0 Release 9 



83 



ETSI TS 126 290 V9.0.0 (2010-01) 



8.3 AMR-WB+ File Storage Format 



This format is relevant only for file storage and defines a storage unit contained in an AMR-WB+ sample of a 3GP file 
[9]. It is quite similar to transport interface format with the exception that the two-octet header is used once per 
superframe for AMR-WB+ extension modes and once per frame for AMR-WB modes. Note that in AMR-WB+, the 
operation code and internal sampling frequency can be switched only on a superframe basis boundaries so the header 
octets are needed only once per superframe. 

All media streams in a 3GP file are stored in timed units called samples. This format defines the syntax of the basic 
component of a sample, which is here called a storage unit.. 

A storage unit consists of a two-octet header followed by data octets corresponding to either: 

1. A whole superframe (4 transport frames) when FT = 10.. 13 or OC = 16. . .47 . 

2. A frame otherwise 

For the first case, the number of data octets per superframe is given by 4 times the number of octets per frame (the 
right-most column in Table 25). 

The length of an AMR-WB + storage unit in ms (corresponding to one superframe) depends on the internal sample 
frequency and given by 80xISF/25600 where ISF is the internal sampling frequency in Hz (ISF modes are shown in 
Table 24). 

The header in each storage unit contains the following two octets. 





MSB 




LSB 


Octet 


bits 


bit? 


bite 


bits 


bit 4 


bits 


bit 2 


bit1 


1 





Frame type (7 bits) 


2 








ISF mode (5 bits) 



Frame type (FT) (7 bits): Indicates the frame type setting of the codec used for the corresponding frame (the 
combination of AMR-WB+ core and stereo mode, the AMR-WB mode, or comfort noise, as specified by Table 25 
above). 

ISF index (5 bits): Indicates the internal sampling frequency employed for the corresponding frame. The index values 
correspond to internal sampling frequency as specified in Table 24 above. This field SHALL be set to for operation 
according to the AMR-WB + modes defined in table 21 (frame types 0-13). 

For frame types according to FT 0-13 the ISF field shall be set and has no meaning. The frame length for that 
operation is fixed to 20 ms in time. 

The audio data follows the header octets. The number of data octets per storage unit corresponding to frame types 
10.. 13 and 16. . .47 are given as 4 times the number of octets per frame (right-most column in Table 25), for the other 
frame types, the number of octets are those corresponding to 1 frame only. 

It should be noticed that when FT <10, i.e. AMR-WB frames, the original AMR-WB storage format should be preferred 
in order to ensure backward decoding compatibility. 

Example 

The following diagram (Table 27) shows a storage sample of AMR-WB+ using 14 kbit/s frame types (FT=26) with a 
superframe length of 4x35=140 octets. The internal sampling frequency in this example is 25.6 kHz (ISF mode = 8). FT 
26 corresponds to mono mode (208 bits/frame) and stereo mode 4 (72 bits/frame). 

The data octets are packetized according to the detailed bit allocation given in tables 14 to 20. The first bit of the AMR- 
WB+ data bO is placed in bit 8 of octet 3. 
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Table 27: AMR-WB+ storage sample (superframe) for 14 kbit/s operation with ISF mode 8 (bit rate 

factor=1). 





MSB 




LSB 


Octet 


bit 8 


bit 7 


bit 6 


bits 


bit 4 


bit 3 


bit 2 


biti 


1 


FT = 26 











1 1 1 
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ISF = 8 
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"""^^ 
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4..27 
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30..36 
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65..71 


































72 






























S70 


S71 


73 






























b6 


b7 


74..97 
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Annex A (informative): 
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Change history 


Date 


TSG SA# 


TSG Doc. 


CR 


Rev 


Subject/Comment 


Old 


New 


2004-09 


25 


SP-040639 


- 


- 


Approved at TSG SA#25 


2.0.0 


6.0.0 


2004-12 


26 


SP-040841 


001 




Correction of stereo bit allocation tables 


6.0.0 


6.1.0 


2004-12 


26 


SP-040841 


002 




Correction of storage format for AMR-WB+ 


6.0.0 


6.1.0 


2004-12 


26 


SP-040841 


003 


1 


Editorial changes 


6.0.0 


6.1.0 


2004-12 


26 


SP-040841 


004 




Editorial changes. Note that in Tdoc S4-040722, this 
CR was meant to be CR 004 and not CR 01 2; a remark 
was put in the CR database. 


6.0.0 


6.1.0 


2005-03 


27 


SP-050096 


005 


1 


Update for TCX coding mode selection table 


6.1.0 


6.2.0 


2005-06 


28 


SP-050252 


006 




Correction of a value in Table 21 


6.2.0 


6.3.0 


2007-03 


35 


SP-070029 


0007 


1 


Reference to users guide 


6.3.0 


7.0.0 


2008-12 


42 








Version for Release 8 


7.0.0 


8.0.0 


2009-09 


45 


SP-090574 


0008 




Correction of references 


8.0.0 


9.0.0 



ETSI 



3GPP TS 26.290 version 9.0.0 Release 9 



86 



ETSI TS 126 290 V9.0.0 (2010-01) 



History 



Document history 


V9.0.0 


January 2010 


Publication 



























ETSI 



